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tions where special processing requirements exist. 
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essing System. 
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Preface 



This publication is a portion of the reference text for 
the ibm 1401 and 1460 Data Processing Systems. The 
full set of manuals provides a detailed explanation of 
all the instructions used by the system to manipulate 
data. Detailed explanations of the instructions used 
with the required and available input/output units at- 
tached to the system are also included. The reader 
should be familiar with the IBM 1401 System Sum- 
mary, Form A24-1401, or the IBM 1460 System Sum- 
mary, Form A24-1496, and the various publications on 
programming material, such as Symbolic Programming 
System (SPS) and Autocoder. 

The complete manual is divided functionally into 
these sections: 

System Operation Reference Manual (A24-3067) 

Section A Introduction 

Section B System Operations 

Section C ibm 1406 Operations 

Section D ibm 1447 Operations 

Section E ibm 1402 and 1403 Operations 



Tape Input/Output Instructions (A24-3069) 
Section F Tape Input/Output Operations 

Disk Input/Output Instructions (A24-3070) 

Section G Disk Input/Output Operations 

Miscellaneous Input/Output Instructions (A24-3068) 
Section H Miscellaneous Input/Output Oper- 
ations 

Special Feature Instructions (A24-3071) 
Section I Special Feature Operations 

The sections are independent and do not have to be 
used in the order in which they appear. A System 
Reference Library can be compiled using those sec- 
tions applicable to the user's machine configuration. 

This publication is intended for programmers and 
systems personnel who have a general knowledge of 
the ibm 1401 or 1460 Data Processing Systems and who 
require a reference text for detailed information. 

Other publications referenced here are, in most 
cases, prerequisites for a complete understanding of 
the material presented in this publication. 
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Special Features 



Adapter, 51 -Column Feed (1401, 1460) 

This feature is required when the 51-column inter- 
changeable-read-feed special feature is installed on the 
ibm 1402 Card Read-Punch, Model 1, for the 1401 
system or the ibm 1402, Model 3, for the 1460 system. 

The adapter furnishes the controlling circuitry neces- 
sary for the proper operation of the 51-column read- 
feed special feature. 

For more detailed information on the 51-column 
interchangeable-read-feed special feature refer to ibm 
1402 Card Read-Punch, A24-3072. 



Advanced Programming (1401) 

The advanced-programming feature provides the 1401 
system with greater program flexibility, by making 
address indexing, address storing, and record move- 
ment more automatic. The various parts of the ad- 
vanced programming feature and their method of oper- 
ation are described in this section. 



Indexing 

The indexing portion of the advanced-programming 
feature provides three 3-position index locations (regis- 
ters) that can be used to modify addresses automati- 
cally. These three index registers are part of core 
storage and can be used as normal storage positions 
when not being used as index-register locations. The 
assigned core-storage addresses and index register 
numbers are: 



?x-Register No. 


Core-S tor age ' Positions 


1 


087 - 089 


2 


092 - 094 


3 


097 - 099 



The index factor can be placed in the index register 
by normal programming ( add or move operations, for 
example) and the factor can be changed (add opera- 
tions normally). In these instances, a word mark should 
be initially set in the high-order position of the index 
register before inserting or changing the index factor. 

Both the A-address and/or the B-address can be 
modified by the index factor in any one of the three 
index registers; however, only core-storage addresses 
can be modified. 



The A- and/or B-address specifies which index reg- 
ister will be used by a combination of A- and B-bits 
in the tens position of the address. The bit combina- 
tions and the registers they specify are: 



Bit Combination 
A-bit, No B-bit 
B-bit, No A-bit 
A-bit, B-bit 



Index Register No. 
1 
2 
3 



Zone Punch 

Zero 

Eleven 

Twelve 



When the tens position of an A- and/or B-address 
contains one of these zone-bit combinations, the ad- 
dress is referred to as being tagged. 



ositions 


Tagged 


I 


I 


AAA 


BBB 



OP 

The modification of the A- and/or B-address occurs 
in their respective address registers. For instance, if the 
A-address is indexed, the indexing occurs in the A- 
address register. This means the original instruction in 
storage is in no way changed or modified. 

When a program is written using the symbolic pro- 
gramming system, indexing is indicated by writing a 
1, 2, and 3 in the index column of the symbolic coding 
sheet ( cc27 for ( A ) operand— cc38 for ( B ) operand ) . 

Digit Result 

1 Index operand by contents of 087-089 

2 Index operand by contents of 092-094 

3 Index operand by contents of 097-099 

The ( A ) and ( B ) operands can be symbolic of actual 
addresses. In the processing of instructions: 

1. The A-address and B-address are analyzed for in- 
dexing as they are moved into the address registers. 

2. The contents of the proper index location (indexing 
factor) are added to the contents of the address 
register and develops the effective address there, 
when indexing is indicated. 

3. Three or four additional cycles are required for 
each address indexed. 



Increasing an Address 

To increase a core-storage address using the indexing 
feature, the contents of the index location are added to 
the selected address register. Figure 1-1 illustrates vari- 
ous methods of address modification using the index 
locations. 



1-1 





INSTRUCTION 
IN STORAGE 


INDEX LOCATION 


EFFECTIVE 
INSTRUCTION 


1 


2 


3 


1. INDEX THE B-ADDRESS 


BEFORE 


M. 080 1A7 


010 


025 


050 




AFTER 


M 080 1A7 


010 


025 


050 


M 080 167 


2. INDEX A- AND B-ADDRESS 


BEFORE 


M 0S0 1J7 


010 
010 


025 
025 


050 




AFTER 


M 0S0 1J7 


050 


M 030 142 


3. INDEX A- AND B-ADDRESS 


BEFORE 


M JBO 8C0 


010 


025 


050 




AFTER 


M JBO 8C0 


010 


025 


050 


M J70 880 



I 



Figure 1-1. Indexing 



Decreasing an Address 

To decrease an address, the 16,000's complement of the 
amount to be subtracted from the address must be 
stored in the index location. 

Example: Decreasing 

Required Decrease a B-address by 10 

Indexing factor 16000-10 (15990) 
( Complement ) 

The 15990 converts to the 3-digit factor 19? (Fig- 
ure 1-2). 

Using the modulus 16 rules, the arithmetic overflow 
adds an A-bit in the hundreds position ( both the hun- 
dreds and units positions already contain A- and B-bits, 
the combination of which indicates a 15000-15999 
block address ) . The addition of the A-bit increases the 
value of the zone bits to 16 which, according to 
modulus 16, has an address value of (000-999 block 
address ) . Therefore, the new address is 927. With the 
indexing feature, even though there was an overflow, 
the arithmetic-overflow indicator is not turned on. 



easier to re-enter the main program from a subroutine. 
Because the address of the next instruction in sequence 
can be retained, program re-entry is simplified. 

A subroutine is a set of program instructions that 
are executed, if a particuler condition arises during 
the main routine. For example, if an unequal compare 
occurs during processing, the program branches to a 
subroutine in which a special set of instructions han- 
dles the condition. 

Each time a subroutine is used, some method must 
be employed to link it with the main program. The 
function of the store a-address register and store 
b-address register instructions is to establish subrou- 
tine linkage so that upon leaving the sequence of the 
main program it is possible to execute the steps of the 
subroutine, and return to the main program where the 
sequence was interrupted. 



Store A- Address Register 



Store Address Register 

The store-address-register portion of the advanced- 
programming special feature makes it possible to store 
the contents of the A- and B-address registers. Thus, 
the A- and B-addresses of program instructions can be 
modified directly in cases where variable-length rec- 
ords are being processed. This facility also makes it 





INSTRUCTION 
IN STORAGE 


INDEX LOCATION 


EFFECTIVE 
INSTRUCTION 

.L_ 123 927 


1 


2 


3 


BEFORE 


L. 123 9T7 


19? 


AFTER 


L. 123 9T7 


19? 







937 + 19? = 927 (with overflow) 
I = (AB9) 
? = (ABO) 



Figure 1-2. Converting Address 
1-2 



Instruction Format. 

Mnemonic Op Code 

SAR Q 



A-address 

XXX 



Function. This instruction stores the contents of the 
A-address register from the previous operation, in 
the 3-position field that has its units position defined 
by the A-address of the store a-address register 
instruction. 

Word Marks. Word marks are not affected. 

Timing. T = .0115 (L r + 5) ms. 

Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
A-3 



B-Add. Reg. 
Ap 



Example. Store the contents of the A-address register 
in area labeled AADRG (0625), Figure 1-3. 



SPS 



SPS 



LIKE 


COUNT 


LABEL 


OPERATION 


(») OPERAND 


(t) OPERAND 


d 


ADDRESS ± ™**' 


1 


ADDRESS 1 ± | C . H **- 


M 


0,1,0 


, 


, , , , ■ 


SA\RAA.D.R,6. ! 1 , , 




! 1 , , 







LINE 


COUNT 


LABEL 


OPERATION 


(A) OPERAND 


(Bl OPERAND 


d 


AOORESS t C A H * R ' 


• 


ADDRESS 1 + 1 CHAR - 
28 1 3< | ADJ. 


i 


0,1,0 







a i 


M,U1,T,RU! ! , , 




,,.,,:!,, 




/ 


2 












- _ 1 1 






0,3,0 






S0IR 


LAST, , If-! , X 




1 1 






4 












1 ,"' , , , 4- 1 -, ,- 






o,»,o 


— I — 


LAST, , 


a : 


OOOO. . I ! , , 











Autocoder 



Autocoder 
















Label 

e 


13 


Operation 
16 20 


21 25 


30 


35 


40 


OPERAND 

45 SO 


I 
, . 


SAR . 


AADRG. 



Assembled Instruction: Q 625 
Figure 1-3. Store Contents of A-Address Register 



Label 
e is 


Operation 

IS 20 


21 25 3< 


> 35 


40 


OPERAND 

45 50 


I 
i , , , 


&u 


rtu^r/ia . , , 








-^ -.i -._ 
























SfiK 


LAsr+* . 








... i __. 












iAsr , i , , , 


fif, , , 


Q 




. , . 1 






Store B-Address Register (One Field) 



Instruction Format. 



Assembled Instruction: ]b 495 

J4 (address machine-assigned) 
B (address in main routine 

following the JB 495 instruction) 

Figure 1-4. Store Contents of B-Address Register ( One Field ) 



Store B-Address Register (Two Fields) 



Instruction Format. 



Mnemonic 


Op Code 


A-address 










SBR 


H 


XXX 


Mnemonic 


Op Code 


A-address 


B-address 




— 




SBR 


H 


XXX 


XXX 



Function. This instruction stores the contents of the 
B-address register resulting from the previous op- 
eration, in the 3-position field that has its units posi- 
tion defined by the A-address of the store b-address 
register instruction. 

Word Marks. Word marks are not affected. 

Timing. T = .0115 (Li + 4 or 5* ) ms. 

* Plus 4 or 5 depends on the presence or absence of zone bits 
in the units position of the address being stored. 

Note. When indexing is installed in the ibm 1401, the function- 
ing of all branch instructions is altered to simplify subroutine 
linkage. With these alterations, each time a branch occurs as 
a result of one of these instructions, the address of the next 
sequential instruction in the main routine is inserted in the 
B-address register. 

Although the subroutine may be entered from many dis- 
tinct points in the main program, this use of the sbr operation 
makes the subroutine linkage complete. 



Function. This instruction stores the present contents 
of the B-address register in the 3-position field that 
has its units position defined by the A-address of the 
store b-address register instruction. The B-address 
register contains the number specified by the B- 
address portion of the store b-address register 
instruction. 

Word Marks. Word marks are not affected. 

Timing. T = .0115 (L T + 4 or 5*) ms. 

* Plus 4 or 5 depends on the presence or absence of zone bits 
in the units position of the address being stored. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
A-3 



B-Add. Reg. 
Bp 



Address Registers After Operation. 



Example. Store contents (456) of the B-address register 
in the area labeled BADRG (123), Figure 1-5. 



I-Add. Reg. 
NSI 



A-Add. Reg. 

A-3 



B-Add. Reg. 
Bp 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


IAI OPERAND 


(» OPERAND 


d 


ADDRESS 1 C 4 H *"' 


= 


ADDRESS ± CH *"' 
21 I34I *"* 


1 


0,1,0 







SS\R 


8,A,D,R.6. ! ! , , 




V.4-.6. ,,::,, 







Example. The main routine branches to a multiply 
subroutine labeled MULTRU (0495). This example 
shows the last step in the main routine and the first 
and last steps of the multiply routine, and illustrates 
subroutine linkage ( Figure 1-4 ) . The last instruction 
(labeled LAST) plus three will contain the address 
of the next instruction in the main routine. 



Autocoder 














Label 

6 


1$ 


Operation 
18 20 


21 25 30 


35 


40 


OPERAND 

43 50 


1 


$M , 


8ADR0.)tkS.6 



Assembled Instruction: H 123 456 

Figure 1-5. Store Contents of B-Address Register (Two Fields) 

1-3 



Move Record (1401; Standard on 1460) 

The move record portion of the advanced-program- 
ming special feature provides a special move instruc- 
tion that makes it possible to move a complete record 
from one storage area to another, without regard to 
word marks within the record. This instruction is espe- 
cially desirable in magnetic tape operations. 
This feature is standard on the 1460 system. 



Move Characters to Record or Group Mark 



Instruction Format. 



Mnemonic 


Op Code 


A-address 


B -address 


SPS MCM 


P 


XXX 


XXX 


A MRCM 









Function. This operation code makes it possible to 
move an entire record from one core-storage area 
to another, regardless of the presence of word marks 
in either field. The A- and B-addresses specify the 
high-order position of the respective areas. Trans- 
mission starts from the high-order addresses, and 
continues until a record mark ( A82 bits ) or a group- 
mark with a word-mark ( WMBA8421 bits ) is sensed 
in the A-field. The record mark or group mark 
transfers to the B-field. 

Word Marks. Word marks within the area do not affect 

the MOVE CHARACTERS TO RECORD OR GROUP MARK 



operation. Any word marks in the B-field remain 
unchanged. A-field word marks are not transmitted 
to the B-field. 

Timing. T = N* (Li + 1 + 2L A ) ms. 

* N = .0115 on 1401 system; 

* N = .006 on 1460 system 

Address Registers After Operation. 

I-Add. Reg. A-Add. Reg. B-Add. Reg. 

NSI A + La B + L A 

(The length of the A-field 
includes the group-mark 
with a word-mark or rec- 
ord mark) 

Example. Move the tape record that has its high-order 
character in the location labeled TARCIN (0679) to 
another area of core storage beginning at the label 
WTAREC (0985), Figure 1-6). 



SPS 



I 



LINE 


COURT 


LABEL 


0PEMTIM 


(A) OPERAND 


(B) OPERAND 


d 


ADDRESS £ ._ ' 


IT 


ADDRESS ± CH *"- 
2. I M I ""• 


H 


0,< ,0 


, 





nC\nTA.R.C.lN\ ! . , 




UTAR£.G ! ■ , 







Autocoder 



Label Operation 

JS!S 20 21 26 M ML 



. . IrtftCAl \TA JRC*IN. ) UTME.C , ■ 



OPERAND 

_«& a as 



Assembled Instruction: P 679 985 



Figure 1-6. Move Characters to Record or Group Mark 
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Binary Transfer (1460) 



Column Binary (1401) 



This special feature makes it possible to process cards 
and magnetic-tape data recorded in column-binary 
form. This provides compatibility between the ibm 
1460 and ibm scientific data processing systems, such 
as the ibm 704, 709, and 7090. 

Auxiliary operations that can be performed for large- 
scale binary systems are: 

1. Card-to-tape. 

2. Tape-to-card 

3. Tape-to-tape 

4. Card-to-card 

5. Card-to-printer 

6. Tape-to-printer 

7. Tape sorting, editing and merging 

8. File maintenance 

This special feature is the same as the column-binary 
special feature on the 1401, with one exception. The 
binary transfer special feature does not have the 
branch if bit equal instruction as does the column- 
binary feature. For more detailed information on this 
feature, refer to the Column Binary section of this 
publication. Replace 1401 timing (.0115) with 1460 
timing (.006) in all instructions. 



This feature makes it possible for the ibm 1401 Data 
Processing System to process column-binary-coded 
cards and magnetic tapes used with ibm scientific data 
processing systems such as the ibm 704, ibm 709, and 
ibm 7090. 

The reading, writing, and logic operational facilities 
of the 1401 can be used to process the binary-coded 
data. 

The operation codes and instructions described in 
this section are used whenever: 

1. The information to be read or written is in binary 
cards or binary-coded tapes. 

2. There are invalid multiple punches in cards con- 
taining the standard ibm card code. This means that 
cards, coded with several punches in one column, 
that were designed for other machines can be en- 
tered by using this feature. 



Read Column Binary 



Instruction Format. 



Mnemonic 


Op Code 


d-character 


SPS R 


1 


C 


A RCB 







Bit Test (1401, 1460) 

This special feature is available on both the ibm 1401 
and 1460 systems. It is a branch instruction that causes 
the character located at the B-address to be compared, 
bit by bit, with the d-character. If any bit in the char- 
acter located at the B-address matches any bit in the 
d-character, the program branches to the specified I- 
address (WM and C-bits are not compared). 

For more detailed information on the bit-test special 
feature, refer to the branch if bit equal instruction in 
the Column Binary section of this publication. Replace 
1401 timing (.0115) with .006 for 1460 timing. 



Function. This instruction causes the card at the read 
station to be read into the 1401 in the binary mode. 
During the reading of a card, the read cycle is 
divided into two parts, and three different areas in 
storage receive the data. Card cycle 9 through 4 
time uses the normal read addresses 001-080, and 
column-binary-read area addresses 501-580. The 
other portion of the card cycle (3-12 time) uses ad- 
dresses 001 through 080, and 401 through 480. Note 
that storage locations 001-080 are common read-in 
locations for both halves of the read cycle. 

At the completion of this read operation a BCD 
coded image of the card is stored in addresses 001 
through 080, just as in normal card reading. The 
portion of the card that contains column-binary in- 
formation appears as hash in the corresponding ad- 
dresses 001-080, and the portion of the card that 
contained alphamerical characters is stored in BCD 
code in addresses 001 through 080. Storage addresses 
401-480 and 501-580 contain the true card image. In 
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BCD CODE 




PUNCHES IN CARD COLUMN 


Storage 


C 
B 










12 


Addresses 


A 
8 










11 



401-480 


4 
2 
1 










1 
2 
3 


Storage 


C 
B 










4 


Addresses 


A 
8 










5 
6 


501-580 


4 
2 
1 










7 
8 
9 


Storage 


C 
B 










12 
11 


Addresses 


A 
8 











1 


001-080 


4 
2 
1 










2 
3 

4 




(BCD 


equivc 


lent of the 


card 


5 




punc 


les 


if 


alphamer 


ical, 


6 




hash 


if true 


binary.) 




7 














8 














9 



Example. Read the card at the ibm 1402 read station in 
the column-binary mode (Figure 1-8). 



SPS 



LIKE 


COUNT 


LABEL 


OPERATIC* 


(A) OPERAND 


It) OPERAND 


d 


ADDRESS i ' 


i 


ADDRESS ± ""' 


H 


DJ,0 


, 


i , i i , 


ft ! 


I , , . i ! 1 i . 




_1 -1 1 l L ' ' _l J 




^ 



Autocoder 
















Labal 

6 


1$ 


Operation 

16 20121 


26 


30 


36 


40 


OPERAND 

43 60 


T 1 


R&R . \ 



Assembled Instruction: 1_ C 
Figure 1-8. Read Column Binary 



I 



Read Column Binary and Branch 

Instruction Format. 

Mnemonic Op Code I-address d-character 

SPS R 1 xxx C 

A RCB — 



Figure 1-7. BCD Code and Column Binary Punches 

these areas all alphamerical characters and all col- 
umn-binary information appear as illustrated in 
Figure 1-7. 

If, for example, the following information is re- 
corded in a binary card and appears in core storage: 

Card-column 1 contains an ibm card-code H which 
is represented by a 12-punch and an 8-punch. 



Storage Locations 
001 
401 
501 



Contains 

BA8 

B 

2 



Card-column 2 is part of a binary field and con- 
tains punches in rows 12, 0, 1, 3, 4, 5, 6, 7, and 9. 



Storage Locations 
002 
402 
502 



Contains 
hash 
CB841 
BA841 



Word Marks. Word marks are not affected. 

Timing. T = .0115 (L T + 1) ms + I/O. 

Note. The read column binary instruction (1C) cannot be 
combined with any other operation. 

Read checking of input data is unchanged, except for the 
validity check, which is not performed because all characters 
read are considered valid. 

Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
dbb 



B-Add. Reg. 
481 



Function. This is the same as read column binary, ex- 
cept that the next instruction is at the I-address. 

Word Marks. Word marks are not affected. 

Timing. T = .0115 (L x + 1) ms + I/O. 

Note. The read column binary and branch instruction 
(lxxxC) cannot be combined with any other operation. 

Read checking of input data is unchanged, except for the 
validity check, which is not performed because all characters 
read are considered valid. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
BI 



B-Add. Reg. 
481 



Example. Read the card at the read station in column 
binary mode, and branch to BININ (0922) for the 
next instruction ( Figure 1-9 ) . 



SPS 



LINE 
3 8 


COUNT 


LABEL 


OPERATION 


(A) OPERAND 


(■1 OPERAND 


d 


ASDftESS i ' 


I 


ADDRESS 1 1 1 C A ""' 


H 


O.l ,0 


, 




R, ! 


R.m.l/4. ! i . . 




_L 1 J j 1 1 ' X J_ 




cl 



Autocoder 














Labal 

6 13 


Operation 
16 20 


21 26 


so 


36 


40 


OPERAND 

46 80 


1 , , , 


kCB. . 


0,/M/A/. , 




.... 


, , , 



Assembled Instruction: J_ 922 C 
Figure 1-9. Read Column Binary and Branch 
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Punch Column Binary 



Punch Column Binary and Branch 



Instruction Format. 



Mnemonic 


Op Code 


d-character 


SPS P 


4 


C 


A PCB 







Instruction Format. 

Mnemonic Op Code I-address d-character 

SPS P 4 xxx C 

A PCB 



Function. This instruction, executed in two parts, re- 
quires that the information be stored in two different 
areas. Information that is to be punched in rows 12-3 
(card columns 1-80) is stored in locations 401-480. 
Rows 4-9 of the card (columns 1-80) are punched 
from storage locations 501-580. 

Using the same data shown in the read column 
binary example, the card is punched: 



Storage Locations 
401 
501 



BCD 
B 

2 



Punches 
12 



This combination causes the H to punch in card 
column 1. 

Card column 2 is punched in rows 12, 0, 1, 3, 4, 5, 
6, 7, and 9 as transferred from: 



Storage Locations BCD 

402 CB841 

502 BA841 



Punches 
12, 0, 1, 3 
4, 5, 6, 7, 9 



Word Marks. Word marks are not affected. 



Timing. T = .0115 (L x + 1) ms + I/O. 

Note. The punch column binary instruction (4C) cannot be 
combined with any other operation. The punch checking of 
output data is unchanged. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



" A- Add. Reg. 
Abb 



B-Add. Reg. 
181 



Example. Punch the card at the punch station in the 
column-binary mode (Figure 1-10). 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


(A) OPERAND 


(Bl OPERAND 


d 


ADDRESS £ 


i 


ADDRESS 1 ± 1 C t *£ R - 


= 


0,1,0 







P ! 










c 



Autocoder 


















Label 


15 


Operation 
ie 20 


21 


25 


SO 


35 


40 


OPERAND 

45 50 


i , , . 


pm , 





Assembled Instruction: 4 C 
Figure 1-10. Punch Column Binary 



Function. This is the same as the punch column 
binary instruction, except that the next instruction is 
taken from the I-address. 

Word Marks. Word marks are not affected. 

Timing. T = .0115 (L T + 1) ms + I/O. 

Note. The punch column binary and branch instruction 
(4xxxC) cannot be combined with any other operation. The 
punch checking of output data is unchanged. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
BI 



B-Add. Reg. 
181 



Example. Punch a card in the column-binary mode, 
and branch to BINCD (0986) for the next instruction 
(Figure Ml). 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


(A) OPERAND 


(Bl OPERAND 


d 


.««-«- 1 + 1 CHAR. 
ADDRESS - 


- 


ADDRESS ± 'I**' 
|| AW. 


^ 


0,1,0 


, 





p, : 


&JM£JL±\ , . 




L 1 l 1 .... I ..' 1 .., 




c 



Autocoder 














Lab«l 

S 15 


Operation 
It 20 


21 25 


30 


35 


40 


OPERAND 

45 50 


, . . , . 1 . . . 


PM . 


B/M.CA 



Assembled Instruction: 4 986 C 
Figure 1-11. Punch Column Binary and Branch 



Branch if Bit Equal 

Instruction Format. 

Mnemonic Op Code 
BBE W 



I-address B-address d-character 

xxx XXX X 



Function. The d-character can contain any character or 
any combination of bits (BA 8421) that can exist in a 
single position of the 1401 core storage. If the char- 
acter at the B-address contains any bit that matches 
any bit in the d-character, the program branches to 
the I-address. Otherwise, the program continues 
normally. 
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Word Marks. Word marks are not affected. 



Timing. T = .0115 (Li + 2) ms. 



Address Registers After Operation. 



l-Add. Reg. 
NSI 



A- Add. Reg. 
BI 



B-Add. Reg. 
B-l 



Example. Examine the storage location labeled UNPOS 
( 0759 ) for a match in the d-character bit configura- 
tion. The d-character is a 9 (8- and 1-bits). There- 
fore, if the character contains either an 8- or 1-bit, 
the program branches to BITEST (0985), Figure 
1-12. 



SPS 



LINE 


COUNT 


LAREL 


OPERATION 


(«l OPERAND 


(II OPERAND 


d 

31 


„ """' |*| '.""' 


8T 


ADDRESS ± "J*" - 


M 


0,1,0 




i , , r i 


B,fl!£ 


ai,T,fS.r: \ ■ , 




UJHJPQS, i ! , . 


V 



Autocoder 



Label |Operation| OPERAND 
S isjie tofci 25 Jfi Sfi Ifi S3 82 



fi,a £ . , Ul I teTfiOtiPD&ffl. 



Assembled Instruction: W 985 759 9 
Figure 1-12. Branch if Bit Equal 



Binary Tape Instructions 

Column-binary information should be recorded on 
magnetic tape in its logical order. To do this it is nec- 
essary to arrange the data from storage locations 401- 
480 and 501-580 in the following sequence in a tape- 
write area: 

Address 401 followed by 501, followed 
by 402, 502, etc., until the entire area 
is so arranged. 

This puts the 12-3 data next to the 4-9 data from the 
same card column, in the proper sequence for writing 
on tape. 

This arranging can be done automatically by a move 
and binary decode instruction. 

Conversely, data read from a tape unit can be ar- 
ranged as a card image with 12-3 punches in the 401- 
480 area and 9-4 punches in the 501-580 area. The 
move binary code operation performs this function. 

Column-binary information must be written on mag- 
netic tape in the odd-parity mode. This means that an 
odd number of bits must be recorded in each position 



of the tape record. The write binary tape and read 
binary tape instructions cause the data to be recorded 
in this manner. 



Move and Binary Decode 

Instruction Format. 

Mnemonic Op Code A-address B-address d-character 
SPS MCW M xxx xxx A 

A MBD — 

Function. This instruction arranges data in the correct 
order for tape writing. The A-address is usually 572 
or 580, depending on whether the card has 72 or 80 
columns of binary data. It specifies the units or low- 
order position of the record. The B-address specifies 
the low-order position of the area in core storage 
from which the record is to be written on tape by a 
write binary tape instruction. The d-character spec- 
ifies that this is a move and binary decode operation. 
At the completion of this operation, the tape-write 
area (B-address) contains the data from both the 
401-480 and 501-580 areas in this sequence: 

401, 501, 402, 502, 403, etc. 

Word Marks. A word mark must be preset in the 401- 
480 area to signify the high-order character of the 
record (normally in location 401). Any word mark 
encountered stops the transfer to the tape-write area. 

Timing. T = .0115 (L : + 1 + 2L B ) ms. 



Address Registers After Operation. 



l-Add. Reg. 
NSI 



A- Add. Reg. 

Address of the 

400 area preset 

word mark + 99. 



B-Add. Reg. 
B-Lb 



Example. Write the data in 401-480 (labeled CLB14A) 
and 501-580 (labeled CLB15A) areas in the tape- 
write area labeled BITPAR (2080), Figure 1-13. 



SPS 



LINE 
i 8 


COUNT 


LABEL 


OPERATION 


(A) OPERAND 


(SI OPERAND 


d 


ADDRESS ± ^j"' 


i 


ADDRESS ± CH *"' 
2t I54I * W 


9* 


0,1,0 


, 




rt,ciu 


G.K.BS.AA! : . 




fl L LTRJJ5L_i_x_ J _ 




A 



Autocoder 



Lobe I Operation 

'S 'e 8fiii___8S_ 



iHffP ■ KA,*l5A. i .B,\.tMR , ■ 



Assembled Instruction: M 580 180 A 
Figure 1-13. Move and Binary Decode 
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Move and Binary Code 

Instruction Format. 



Mnemonic 


Op Code 


A-address 


B-address 


d-character 


SPS MCW 


M 


XXX 


XXX 


B 


A MBC 











Function. Information read from magnetic tape is ar- 
ranged into a coded card image in binary form, when 
this instruction is used. Data to be punched in rows 
12-3 is transferred to core-storage-area locations 401- 
480, and data to be punched in rows 4-9 is stored in 
the 501-580 area for punching. The A-address spec- 
ifies the units position of the tape read-in area, and 
the B-address is usually 572 or 580, depending on 
the number of columns to' be punched. The d-char- 
acter ( B ) specifies a move-binary-code operation. 

Word Marks. A word mark must be preset in the high- 
order position of the B-field (normally 401) to stop 
the operation. 

A word mark in the high-order position of the 
A-field can be set to stop the operation after the 
following B-cycle if desired. 

Timing. T = .0115 (L T + 1 + 2L B ) ms. 

Address Registers After Operation. 

1-Add. Reg. A-Add. Reg. B-Add. Reg. 



NSI 



A-La The address of the 

preset word mark in 
the 400 area + 99. 



Example. Move the data from the tape read-in area, 
labeled BITPAR (2080), to the column-binary punch 
area CLB14A (0401-0480) and CLB15A (0501-0580), 
and store it in the proper sequence for punching 
(Figure 1-14). 



SPS 



LIKE 


COUNT 


LABEL 
• IS 


OPERATIC* 


(Al OPERAND 


(■) OPERAND 


d 


A00RE9S ± "*"' 


§ 


ADDRESS ± '"*"• 


» 


0,1,0 






rtcik 


BIT .PARI ! , , 




C.L.BiSA: : . 




B 



Autocoder 



Label Operation 

js.fi 20 81 26 



I ■ ■ . NflC \B LT.PM j£LBlSA . 



OPERAND 
_1S 62 



Assembled Instruction: M 180 580 B 
Figure 1-14. Move and Binary Code 

Write Binary Tape 

Instruction Format. 



Mnemonic 


Op Code 


A-address 


B-address 


d-character 


SPS MU 


M 


%Bx 


XXX 


W 


A WTB 











Function. This instruction writes a tape record in the 
odd-parity mode. The A-address specifies the tape 
unit to be selected, and signals that this is a column- 
binary-tape operation. The B-address specifies the 
high-order position of the tape record in core stor- 
age. The d-character indicates a tape-write opera- 
tion. The sensing of a group-mark with a word-mark 
in core storage stops transmission from the system to 
the tape unit. 

Word Marks. Word marks are not affected. 

Timing. T = .0115 (L : + 1) ms + T M . 

Address Registers After Operation. 



I-Add. Reg. 

NSI 



A-Add. Reg. 

%2x 



B-Add. Reg. 
GM-WM + 1 



Example. Write a tape record in the binary mode on 
the tape unit labeled 4, with the data stored in the 
area labeled BTPOUT (2001) and ending at the 
group-mark with a word-mark sensed in core storage 
(Figure 1-15). 



SPS 



LINE 
3 8 


COUNT 


LABEL 


OPERATION 


(A) OPERAND 


(•) OPERAND 


d 


ADDRESS ± "**' 


I 


ADDRESS ± C "*"- 
# || ADJ. 


d 

M 


, 1 i 


, 





tf.O. %>M> ,,!!,. 




$.T.P.6.U.T ! . . 




u 



Aut 


ocoder 














6 


Label 


IS 


Operation 

16 20 


21 26 30 


36 


40 


OPERAND 

46 SO 


1 
1 , , . 


WIS . 


tyBTPAUT, 



Assembled Instruction: M %B4 101 W 
Figure 1-15. Write Binary Tape 



Read Binary Tape 



Instruction Format. 



Mnemonic 


Op Code 


A-address 


B-address 


d-character 


SPS MU 


M 


%Bx 


XXX 


R 


A RTB 











Function. A tape record written in binary form is read 
into core storage, beginning at the location specified 
by the B-address and ending at an inter-record gap 
between tape records or a group-mark with a word- 
mark in core storage. The A-address indicates the 
tape unit selected, and signals the column-binary 
tape operation. The d-character ( R ) specifies a read 
operation. 

Word Marks. Word marks are not affected. 
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Timing. T = .0115 (Li + 1) ms + T B 



Address Registers After Operation. 



1-Add. Reg. 

NSI 



A-Add. Reg. 



B-Add. Reg. 
Message Length + 1 



Example. Read the binary tape record from the tape 
unit labeled 5 into the area of core storage labeled 
BTPIN (2080) and ending at the group-mark with a 
word-mark sensed in core storage or at the first inter- 
record gap encountered in the tape record (Figure 
1-16). 

SPS 



LIHC 


COUNT 


L«EL 


OPERATION 


(A) OPERAND 


(1! 0*CK»ND 


d 


ADDRESS ± '"*"■ 
,7 l»l * W ' 


i 


ADDRESS |±| C "*'- 

M ImI "* 


M 


O.liO 


, 




M,u\ 


%£.S. ..!!.. 




BJ^IM ! ! . . 




rt 



Autocoder 
















Label 

6 


15 


Operation 

16 20 


II 26 


so 


36 


40 


OPERAND 

46 SO 


1 


RX6, . 


S..ATP.IM 











Assembled Instruction: M %B5 180 R 
Figure 1-16. Read Binary Tape 



Compressed Tape (1401, 1460) 

This feature makes it possible for the ibm 1401 and 
1460 Data Processing Systems to read compressed tape 
prepared by the ibm 7070 Data Processing System, and 
to expand it within core storage for processing by the 
stored program. 

The 7070 writes a compressed-tape record under 
control of the write with zero elimination (twz or 
twc) instruction. By using this 7070 instruction, as 
many as five high-order zeros in each numerical word 
in storage can be eliminated while the data is recorded 
on magnetic tape, thus conserving tape capacity and 
read-write time. 

The READ COMPRESSED TAPE and MOVE AND INSERT 

zeros operation codes are incorporated in the 1401 to 
enable it to process compressed-tape records. 



Function. This operation code causes an entire tape 
record to be read into core storage beginning at the 
B-address and ending with the detection of an inter- 
record gap ( IRG ) in the tape record. A group-mark 
without a word-mark is placed in storage at the right 
of the last data character transmitted when the IRG 
is sensed. At the end of the operation, the B-address 
register contains the address of the inserted group 
mark. 

Mode changes (alpha to numerical and vice versa) 
are made automatically, and are controlled by the 
presence of mode change characters ( A ) in the tape 
record. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms + T M . 



Address Registers After Operation 
A-Add. Reg. 



1-Add. Reg. 

NSI 



B-Add. Reg. 

Address of the inserted 

group mark 



Example. Read a tape record from tape unit 2 (labeled 
2) in the area of core storage labeled TPAREA 
(0498), Figure 1-17. 



SPS 



LIKE 

3 e 


COUNT 


LAiEl 
1 IS 


OPERATION 


It) OPERAND 


(II OPENANO 


d 

3» 


ADDRESS ± 

IT 1 es 


CHAN. 
ADJ. 


«7 


ADDRESS ± "I*"' 


M 


0,1,0 


, 


, . , i , 


fW! 


%.C%, .,!!,, 




EEA8JEA 1 ^ 




R 



Autocoder 



Label Operation 

-ISIS MfcL, U. 



OPERAND 
iit 15 SB 



....!.. . \h u . . KCZ JT/nREAjR . ..^ 

Assembled Instruction: M^ %C2 498 R 
Figure 1-17. Read Compressed Tape 



Move and Insert Zeros 



Instruction Format. 



lemonic 


Op Code 


A-address 


B-address 


MIZ 


X 


XXX 


XXX 



Read Compressed Tape 



Instruction Format. 



Mnemonic 


Op Code 


A-address 


B-address 


d-character 


MU 


M 


%Cx 


XXX 


R 



Function. The move and insert zeros instruction 
moves the compressed tape data that was read into 
core storage by a read compressed tape instruction 
to another storage area, and expands each field to fill 
the storage locations allotted to it by the field-defin- 
ing word marks. The A-address specifies the units 
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position of the compressed tape record in core stor- 
age. (To obtain the A-address, execute a store 
b-address register instruction immediately follow- 
ing the execution of the read compressed tape in- 
struction. This stores the address that contains the 
group mark ( ^ ) that indicated the end of the com- 
pressed tape record.) The B-address of the move and 
insert zeros instruction specifies the units position 
of the expanded area. The data moves from the com- 
pressed area to the expanded area, and zeros are in- 
serted into the high-order positions of the expanded- 
area fields. 

Word Marks. Word marks must be preset in the ex- 
panded area to indicate the high-order position of 
each field. A group-mark, with a word-mark that has 
also been preset by the program, must appear at the 
position immediately to' the left of the high-order 
storage location of the A-field. It is this group mark 
that signals the end of the move and insert zeros 
operation. 

Timing. T = N (L r + 1 + 2 2 L A 2 L z ) ms. 

2 = Number of fields included in an operation. 



Note. When the ibm 7070 writes a tape record, it writes each 
word on tape in either the alphabetic or numerical mode. 
Each time the mode changes from alphabetic to numerical or 
vice versa, a mode change character, delta (A), is automati- 
cally written on tape. Each time a delta is read into core 
storage by the read compressed tape instruction, it changes 
the setting of an internal switch to either the alphabetic or 
the numerical indication, corresponding to the mode. Thus, 
at the completion of the operation, the mode change switch 
indicates the mode setting of the last tape character read. 

In the expand operation, the setting of the internal mode 
switch determines the method of operation. The machine 
works on the move and insert zeros operation from right to 
left, moving the data, field by field, from the compressed area 
to the expanded area. If the compressed-area field is alpha- 
betic, it is moved, intact, to the expanded-area field, as de- 
fined by the preset word marks. To ensure proper operation, 
the expanded alphabetic fields should be equal in length to 
the alphabetic fields read from tape. If the data are numeri- 
cal, they are moved digit-by-digit, low order to high order, 
until a zone bit ( indicating sign position ) or A ( delta ) is en- 
countered. If any high-order positions in the expanded field 
are unfilled, zeros are inserted until a word mark is sensed. 
During this operation, the detection of a A in the compressed 
area changes the setting of the mode switch, and the mode 
of operation changes from alphabetic to numerical, or vice- 



Address Registers After Operation. 



Example. A 4-word compressed-tape record is prepared 
by the ibm 7070: 



1-Add. Reg. 

NSI 



A-Add. Reg. 
Address of preset 
group-mark with a 
word-mark — 1 at im- 
mediate left of tape 
read-in area. 



B-Add. Reg. 
At last word-mark 
in B-field minus one. 



Field 


Mode 


IBM 7070 Storage Words 


Part name 


alpha 


two words 


Part number 


numerical 


one word, always plus 


Unit Cost 


numerical 


one word, always plus 



The part number can be from two to seven digits 
in length. The unit cost can be from three to six 
digits. The compressed-tape record, written by the 
7070 for a specific part, looks like this: 

EXTbbSHANKA0475C1154E 

The letter C is a plus sign over units digit 3. The E 
is a plus sign over units digit 5. The mode switch is 
set to alpha mode during the compressed tape oper- 
ation instruction time. Therefore, it was changed to 
the numerical mode by the A. It is necessary to per- 
form the expand operation before the next read 
compressed tape instruction. 

Figure 1-18 shows the three program steps that 
read and expand the compressed-tape record for this 
example. A group-mark with a word-mark has been 
preset in position 0699. 

The read compressed tape instruction reads into 
core-storage locations 0700-0721: 

EXTbbSHANKA0475C1154E $ 

After the operation, the B-address register contains 
the address of the group mark (0721). The store 
b-address register instruction modifies the move 
and insert zeros instruction so that the A-address 
contains 721: 



000 

721 



724 
724 



before 
after 



The maximum size of the compressed tape record 
is 24 positions (to accommodate a 10-character part 
name, a 7-digit part number, a 6-digit unit cost, and 
the mode-change character). Thus, the expanded 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


(Al OPERAND 


(8) OPERAND 


d 


ADORES* |±| »*"■ 


i 


ADDRESS 111 C "» R ' 
26 IjJ *° J - 


3tt 


0,1,0 


, 




m\ 


&C£^_^ : i ^ 




o7o.o. . : ! , , 




ft 


0,2,0 


, 




3&R 


EX.PAHD\t\ 3 










0,,,0 




£XPAM£> 


miz 


O,0,0,o, , ! ! , , 




inM^ !.!..,,.. 




.... 



Label 
e 15 


Operation 
16 20 


21 25 30 35 


OPERAND 

40 45 80 


1 
1 , , . 


M.IJ. . . 


&C./?., 7.0/J , « 




S/*/?. , 


FXPAfOD,-f-.3, 


fX.PAN.Dl 


mx, , 


OjTfctf 



Assembled Instruction: 

to, %C2 700 R located in storage positions 433-440 
_H 448 located in storage positions 441-444 

_X 000 724 located in storage positions 445-451 

Figure 1-18. Move and Insert Zeros 
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area is defined as locations 700-724 (the 25th posi- 
tion is for the group mark, i ) . Word marks are 
preset in positions 700, 711, and 718. 

The move and insert zeros instruction first tests 
the mode switch, and then moves the unit cost field 
and the group mark (1154E EJE) from the compressed 
field locations, 716-721, to the expanded field loca- 
tions, 719-724. The detection of the zone bits in the 
letter C of the part number indicates the units posi- 
tion of the next field. Because no mode-change char- 
acter is detected, the mode switch continues to 
indicate numerical. A zero is inserted in position 718. 
The preset word mark in that position stops the in- 
sertion of additional zeros in the unit-cost expanded 
field. In a similar way, the 0475C part number moves 
from positions 711-715 to positions 713-717, and 
zeros are inserted in positions 712 and 711, halted by 
the word mark in location 711. The A in position 710 
indicates the units position of the next field (part 
name ) . 

The A changes the setting of the mode-change 
switch from numerical to alphabetic. In the alpha- 
betic mode, characters are moved without insertion 
of zeros. 

The expanded area in core storage after the oper- 
ation looks like this: 

EXTbbSHANKA000475C01154E $ 

Note: To conserve storage, the compressed area overlaps 
with the expanded area in this example. 



Direct Data Channel (1401, 1460) 



Console (1447, Model 2 or 4) 
Attachment (1460) 

This special feature provides for the attachment of a 
console input-output printer to the 1460 system. 

For more detailed information on the 1447, refer to 
ibm 1447 Console, Form A24-3031. 



Console Inquiry Station Adapter (1401) 

This feature provides the additional circuitry to attach 
an ibm 1407 Console Inquiry Station to the 1401. For 
more detailed information on the 1407, refer to ibm 
1407 Console Inquiry Station, Form A24-3084. 



This feature provides for the attachment of the follow- 
ing data processing systems through their serial I/O 
adapters: 1401-1401; 1401-1440; 1401-1460; 1440-1440; 
1440-1460; 1460-1460. 

With the direct-data-channel special feature, the 
two processing systems are cable-connected through 
the serial I/O adapter feature on each system. When 
the direct data channel feature is in use, no other 
input-output unit can use the serial I/O adapter fea- 
ture on either system. 

The cable length between the two systems can be 
any length up to a maximum of 100 feet. 

Data transmission takes place serially by character 
and parallel by bit (WM BA8421 plus a parity bit). Be- 
cause word marks can be transmitted, the 1401 systems 
must have the engineering change installed that adds 
the WM bit line. 

The type of data transmission operation that can be 
performed is varied and at the discretion of the cus- 
tomer. Depending on the written program, both sys- 
tems can send and receive data, or one system can send 
data only while the other system can receive data only. 
To permit this flexibility, the direct-data-channel fea- 
ture makes use of three types of instructions: 

1. signal control instructions 

2. branch instructions 

3. move and load instructions. 



Signal Control Instructions 

The signal control instructions are used by one proc- 
essing system to: 

1. inform the other processing system that it wants to 
perform a particular operation, or 

2. actually perform a particular function in the other 
system. 

Note: The Autocoder mnemonic for select stacker instruc- 
tion (SS) can be used with the C, D, and E d-characters for 
direct-data-channel instructions. 

The diagnostic phase of Autocoder will flag the instruction as 
an error, because it assumes that the d-character represents a 
stacker. However, the error flag can be ignored because the 
assembled instruction in the output object program will contain 
the intended (C, D, and E) d-characters. 
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Read Request 

Instruction Format. 

Mnemonic 
SS 



Op Code 
K 



d-character 
C 



Function. This instruction informs the other system 
that the system initiating this instruction wants to 
read (receive) data from the other system. This 
condition is tested for in the other system with its 
13 (III) 3 instruction. 

Word Marks. Word marks are not affected. 



Example. The system executing this instruction signals 
the other system that it wants to send data to the 
other system ( Figure 1-20 ) . 
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Assembled Instruction: K D 
Figure I-2Q. Write Request 



Timing. T = N (Lt + 1) ms. 
Address Registers After Operation. 



I-Add. Reg. 

NSI 



A- Add. Reg. 
dbb 



B-Add. Reg. 
dbb 



Example. The system executing this instruction signals 
the other system that it wants to receive data from 
the other system (Figure 1-19). 
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Assembled Instruction: K C 
Figure 1-19. Read Request 



Write Request 

Instruction Format. 

Mnemonic 
SS 



Op Code 
K 



d-character 
D 



Function. This instruction informs the other system 
that the system initiating this instruction wants to 
send (write) data to the other system. This condition 
is tested for in the other system with its B ( III ) 4 
instruction. 

Word Marks. Word marks are not affected. 

Timing. T = N (L T + 1) ms. 



Address Registers After Operation. 



I-Add. Reg. 

NSI 



A-Add. Reg. 
dbb 



B-Add. Reg. 
dbb 



Reset 

Instruction Format. 

Mnemonic 
SS 



Op Code 
K 



d-character 
E 



Function. This instruction originates a signal that resets 
the end of transmission circuitry in the other system. 
This reset operation cannot be tested for in the other 
system. 

This instruction must be given prior to each exe- 
cution of a read or write data instruction. It must 
be executed by the 1401 (if one of the machines 
is a 1401 ) every time the other machine is started or 
restarted. This is the only way to reset the end-of- 
transmission circuitry in the other machine, because 
the 1401 start-reset key does not include such a 
function. 

Word Marks. Word marks are not affected. 

Timing. T = N (L : + l) ms. 

Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
dbb 



B-Add. Reg. 
dbb 



Example. Reset the end of transmission circuitry in 
the other system (Figure 1-21). 



Autocoder 



Label Operation 
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Assembled Instruction: K E 
Figure 1-21. Reset 
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Branch Instructions (Direct Data Channel) 

Branch if Indicator On 

Instruction Format. 



Mnemonic 
BIN 



Op Code 
B 



l-address 
III 



d-character 



Function. This instruction and its associated d-charac- 
ters are used by the system initiating these instruc- 
tions to check for various conditions on the other 
system. When a tested condition is present, the pro- 
gram branches to the previously written subroutine. 
The branch if indicator on instruction d-charac- 



ters, and the tests they perform, are shown in 
Figure 1-22. 

Word Marks. Word marks are not affected. 

Timing. 
No Branch: 

T = N (L x + 1) ms. 

Branch (without indexing): 

T = N (Lt + 1) ms. 

Branch (with indexing): 

T = N (Li + 2) ms. 



I 



Condition in System Initiating 
Line/Signal (System A) 


Line/Signal 


System B, Testing Conditions in System A with 
Branch -If-lndicator-On Instructions 


Sent Reset By 


Branch Instruction * Indicator Reset 


Process Check due to detection of 
Transmission Error 


Start Reset Key 


B (III) 1 By executing the Branch Instruction 
in System B, or by pressing Start 
Reset Key in System A; both alterna- 
tives after pressing the Check Reset 
Key in System A. 


End of Transmission. 

A GMWM was reached in the 

System A I/O — area during the 

previous data transfer. 

(The I/O — area in System A was 

smaller or equal in size to that of 

System B.) 


I/O Disconnect 1401, 1440, 1460 
Executing a K E 
instruction in the 
other system. 
1440, 1460 
Start Reset Key. 


B (III) 2 By executing a K E Instruction in 

System B or by pressing the Start Reset 
Key in System A, if System A is a 
1440 or 1460 System. 
Note: This Indicator must be off in 
both Systems before initiating any 
data transfer. 


A Read Request Instruction (K C) 
has been executed in System A. 


Read Request Start Reset Key 


B (III) 3 By executing a Write Data (with or 
without Word Marks) instruction, or 
pressing the Start Reset Key in 
System A. 


A Write Request Instruction (K D) 
has been executed by System A. 


Write Request Start Reset Key 


B (III) 4 By executing a Read Data (with or 
without Word Marks) Instruction, or 
pressing the Start Reset Key in 
System A. 


A Write Data Instruction is being 
executed in System A. 


Start Reset Key 


B (III) 6 When System A ends the Write opera- 
tion. (This is done when System B has 
executed a Read Instruction or by 
pressing the Start Reset Key in System 
A, or if the Indicator 2 was not reset 
in System A.) 


A Read Data Instruction is being 
executed in System A. 


Start Reset Key 


B (111)7 When System A ends the Read opera- 
tion. (This is done when System B has 
executed a Write operation or by 
pressing the Start Reset Key in System 
A, or if the Indicator 2 was not reset 
in System A.) 


System A stopped (Stop key pressed, 
STOP Instruction, error stop, etc.) 


Start Reset Key 


B (III) 8 When System A starts. 



* The d-character must be in the operand field when using a BIN mnemonic. 

Figure 1-22. Branch if Indicator On Instruction Summary 
1-14 



Address Registers After Operation. 

I-Add. Reg. A-Add. Reg. B-Add. Reg. 
No Branch NSI BI Abb 

Branch (without 

indexing) NSI BI Blank 

Branch (with 

indexing) NSI BI NSI 

Example. Test for end of transmission by other sys- 
tem. If the other system did signal an end of trans- 
mission, branch to MSGSNT (0843), Figure 1-23. 

Autocoder 
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Operation 
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OPERAND 
_jU ftfi 



IrUM lM3.fi.fi nr., 2 



Assembled Instruction: B> 843 2 
Figure 1-23. Branch if Indicator On 



Read Data 

Instruction Format. 

Mnemonic Op Code A-address B-address d-character 
MU M SHI xxx R 

Function. This instruction causes the data sent from 
the other system to read into core storage, beginning 
at the core-storage location specified in the instruc- 
tion. 

Word Marks. Word marks are not stored when operat- 
ing in the move mode (M operation code). 

Timing. T = N ( Li 4- 1 ) ms + transmission and start 
time. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 

%81 



B-Add. Reg. 
B + message length + 1 



Move and Load Instructions 

The move or load instruction (M or JL (% H 1) (B B B) 
R or W ) is used by the systems to transmit or receive 
the data in either the move mode or the load mode. 
The parts of the instruction and their use are: 

M or L— The MorL operation code specifies whether 
the data transmission will be performed in the move 
mode or load mode. If the move mode is specified, 
up to 7 bits per character (CBA8421) are involved in 
the data transmission. If the load mode is specified, 
up to 8 bits per character (WM CBA8421) are in- 
volved in the data transmission. The same mode 
must be used by both systems for any one particular 
data transmission. Word marks would be lost if the 
message transmission were in the load mode, but 
the message reception were in the move mode. 

% H 1 — The A-address (% H 1) specifies that the di- 
rect data channel feature is used in performing this 
instruction. 

BBB- The B-address specifies the high-order posi- 
tion of the message in core-storage area involved in 
the data transmission. 

R or W — A d-character of R specifies a read operation. 
This d-character is used when the other system is 
sending the data. A d-character of W specifies a 
write operation. This d-character is used when the 
other system is receiving the data. 

The move and load instructions used, and the opera- 
tions they initiate, are: 



Example. Read data from the other system and place 
it in core storage, beginning at location 0633 (area 
is labeled INPDAT), Figure 1-24. 
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Assembled Instruction: M %H1 633 R 



Figure 1-24. Read Data 



Read Data with Word Marks 

Instruction Format. 

Mnemonic Op Code A-address B-address d-character 
LU L %H1 xxx R 

Function. This instruction is similar to the read data 
instruction except that word marks in the record 
area of core storage are removed, and word marks 
sent with the other data are written in core storage. 

Word Marks. Word marks transmitted from other sys- 
tems are written in core storage. 

Timing. T = N ( Li + 1 ) ms + transmission and start 
time. 
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Address Registers After Operation. 



Write Data with Word Marks 



1-Add. Reg. 
NSI 



A-Add. Reg. 

%81 



B-Add. Reg. 
B + message length + 1 



Example. Read data from the other system, with its 
associated word marks, and place it in core storage, 
beginning at location 0633 (area is labeled INP- 
DAT), Figure 1-25. 
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Assembled Instruction: L %H1 633 R 
Figure 1-25. Read Data with Word Marks 



Write Data 

Instruction Format. 

Mnemonic Op Code A-address B-address d-charactei 
MU M %H1 xxx W 

Function. This instruction causes data to be sent to the 
other system from core storage, beginning at the 
core-storage location specified in the instruction. 

Word Marks. Word marks are not sent to the other 
system when operating in the move mode (M opera- 
tion code). 

Timing. T = N ( Li + 1 ) ms + transmission and start 
time. 



Address Registers After Operation. 



1-Add. Reg. 
NSI 



A-Add. Reg. 



B-Add. Reg. 
B + message length + 1 



Example. Send data to the other system from the core- 
storage area labeled OUTDAT ( first position of the 
data located in 0633), Figure 1-26. 
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Assembled Instruction: M %H1 633 W 



Figure 1-26. Write Data 
1-16 



Instruction Format. 

Mnemonic Op Code A-address B-address d-character 
LU L %H1 xxx W 

Function. This instruction is similar to the write data 
instruction except that word marks in the output 
area of core storage are transmitted with the asso- 
ciated data. 

Word Marks. Word marks are sent to the other system. 

Timing. T = N ( L T + 1 ) ms -f- transmission and start 
time. 



■ 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 

%81 



B-Add. Reg. 
B + message length + 1 



Example. Send data to the other system, with its asso- 
ciated word marks, from the core-storage area la- 
beled OUTDAT (first position of the data located 
in 0633), Figure 1-27. 
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Label Operation 



OPERAND 
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Assembled Instruction: JL %H1 633 W 
Figure 1-27. Write Data with Word Marks 

Instruction Utilization in the Program 

With the instructions just described, the specific type 
of system-to-system data transmission can be set up. 
The type of operation performed is at the discretion 
of the user because the operation is completely pro- 
grammed. 

Each system has its own specifically designed pro- 
gram, using the previously described instructions. Some 
instructions are used in both programs, while other in- 
structions might appear in only one program, if at all. 
The instructions used are completely dependent on the 
specific type of data transmission involved. 



1-Way System-to-System Data Transmission 

To illustrate one kind of system-to-system data trans- 
mission, assume a hypothetical case where one system 
sends data only, while the other system receives data 
only. The program procedure illustrated in Figure 1-28 
is meant only as an example to show the use of the 
various instructions and should not be considered the 
optimum procedure for this kind of operation. 
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Other System 
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Sending-System Operation 

1. The sending system enters its system-to-system 
data transmission program and executes a branch 
if indicator on instruction, B (III) 8, which 
checks to see whether the other system is operating. 

2. If the other system is stopped for any reason, the 
program branches into a previously specified sub- 
routine, which may for example: 

a. permit processing of some other information, or, 

b. stop the system that initiated the instruction or, 

c. notify the system operator in some way. 

3. If the other system is operating, another branch if 
indicator on instruction, B (III) 7, is executed, 
which checks the other system to see whether it is 
trying to execute a read instruction. If the other 
system is trying to execute a read instruction, it in- 
forms the sending system by setting the indicator 
tested by a B (III) 7 instruction. 

4. When a B (III) 7 instruction results in a branch, 
the sending system immediately executes a write 
instruction, M or L (% H 1) (B B B) W. 

The actual data transmission occurs between the 
two systems and continues until one of the systems 
encounters a preset group-mark with a word-mark 
in its core storage. The group-mark with a word- 
mark terminates the data transmission operation 
and sends a termination signal to the other system. 

5. If any transmission error occurs in the sending 
system during the data transmission, the sending 
system stops at the end of the data transmission 
operation. 

6. The system operator must start the system operat- 
ing again and will either try to send the data again 
( step 4 ) or start at the beginning of the subroutine 
(step 1). 

7. If no transmission error occurred in the sending 
system during the data transmission, then the core- 
storage address contained in the B-address register 
is stored in a location specified by the store b- 
address register instruction, II ( x x x ) . This in- 
formation is used later to determine whether the 
complete message was transmitted. 

8. A branch if indicator on instruction, JB (1 1 1) 1 is 
executed, which checks to see whether any trans- 
mission errors occurred in the other system. 

9. If any error occurred in the other system, the end- 
of -transmission circuitry in that system is reset (KE 
instruction) and the sending system tries to send 
the data again. The actual data transmission does 
not start until the operator corrects the error con- 



dition in the other (receiving) system and starts 
that system operating again. 

10. If no transmission error occurred, a branch if indi- 
cator on instruction, B_ (1 1 1) 2, is executed, which 
checks to see whether the other system ended the 
data transmission. 

11. If the other system did not end the data transmis- 
mission, it means that the entire message was trans- 
mitted. The subroutine ends, and the system re- 
turns to its main program. 

12. If the other system did end the data transmission, 
a check must be made to see whether the entire 
message was transmitted. One method that could 
be used is to compare the address stored in step 7 
with the address known to be the last core-storage 
address in the sending system data area. 

9. If the two addresses do not compare, then the end- 
of-transmission circuitry in the other system is 
reset, and the sending system tries to send the data 
again (step 4) because the receiving system did not 
receive the complete message. 

13. If the two addresses do compare, it means that the 
entire message was transmitted. The end-of-trans- 
mission circuitry in the other system is reset. 

11. The subroutine ends, and the system returns to its 
main program. 

There is one other condition that could have oc- 
curred in the sending system. This is the condition that 
occurs when the other system is not trying to execute 
a read instruction. 

3. A branch if indicator on instruction, B (1 1 1) 7, is 
executed, which checks to see whether the other 
system is trying to execute a read instruction. 

14. If the other system is not trying to execute a read 
instruction, then the sending system informs the 
other system that the sending system wants to send 
data by executing a write request instruction, KD. 



Receiving-System Operation 

In the receiving system operation being used in this 
example, there are three conditions that might occur: 

1. Sending system wants to send data, or, 

2. Sending system is trying to execute a write in- 
struction, or, 

3. Sending system does not want to send data and is 
not trying to execute a write instruction. 

Each one of these situations is discussed. 
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15. The receiving system enters its system-to-system 
data transmission program and executes a branch 
if indicator on instruction, B (I I I) 8, which 
checks to see whether the other system is operating. 

16. If the other system is stopped for any reason, the 
program branches into a previously specified sub- 
routine that may be similar to the subroutine de- 
scribed in step 2. 

Condition I— Sending system wants to send data. 

17. If the other system is operating, another branch if 
indicator on instruction, B (I I I) 4 is executed. 
This instruction checks to see whether the other 
system wants to send data. This condition origi- 
nated in step 14 of the sending system program. If 
the other system wants to send data, the receiving 
system immediately tries to execute a read instruc- 
tion, M or L (% H 1) (B B B) R. The data trans- 
mission does not take place immediately, however. 
In trying to execute a read instruction, the receiv- 
ing system signals the sending system that it is 
trying to execute a read instruction. After a negli- 
gible time interval, the sending system enters its 
system-to-system data-transmission program and 
this condition initiates the data transmission pre- 
viously described in step 4. 

18. When the execution of a B (I I I) 4 instruction 
results in a branch, the receiving system imme- 
diately executes a read instruction, M or ^L (% H 1) 
(B B B) R. 

The actual data transmission occurs between the 
two systems and continues until one of the systems 
encounters a preset group-mark with a word-mark 
in its core storage. The group-mark with a word- 
mark terminates the data transmission operation 
and sends a termination signal to the other system. 

19. If any transmission error occurs in the receiving 
system during the data transmission, the system 
stops at the end of the data transmission. 

20. The system operator must start the system operat- 
ing again and will either try to receive the data 
again (step 18) or start at the beginning of the sub- 
routine (step 15). 

21. If no transmission error occurred in the receiving 
system during the data transmission, then a branch 
if indicator on instruction, B ( 1 1 1 ) 1 is executed, 
which checks to see whether any transmission er- 
rors occurred in the other system. 

22. If any error occurred in the other system, the end- 
of -transmission circuitry in that system is reset and 
the receiving system tries to receive the data again 
(step 18). 



23. If no transmission error occurred, a branch jf indi- 
cator on instruction, B (I I I) 2 is executed, which 
checks to see whether the other system ended the 
data transmission. 

24. If the other system did not end the data transmis- 
sion, it means that the receiving system read-in 
area was not large enough to accept the incoming 
message. A subroutine is executed to readjust the 
read-in area so that it can accept the entire incom- 
ing message, and the receiving system tries to re- 
ceive the data again (step 18). 

At approximately this same time, steps 10, 12, and 9 
are being executed in the other system. As previously 
described in these steps, the other system automatically 
tries to send the message again. As soon as the read-in 
area is adjusted, another data transmission operation 
takes place. 

25. If the other system did end the data transmission, 
then the end-of-transmission circuitry in the other 
system is reset by initiating a reset (KE) in- 
struction. 

26. The subroutine ends and the system returns to its 
main program. 

Condition 2— Sending system trying to execute a write 
instruction. 

27. If the other system is operating, and is not trying 
to send data, another branch if indicator on in- 
struction, B (III) 6 is executed. This instruction 
checks to see whether the other system is trying to 
execute a write instruction as a result of an oper- 
ator intervention or some other condition. If the 
other system is trying to execute a write instruc- 
tion, it informs the receiving system by setting the 
indicator tested by a B ( I I I ) 6 instruction. When 
the execution of a B ( I I I ) 6 instruction results in 
a branch, the program previously described in 
steps 18-26 is executed. 

Condition 3— Sending system does not want to send 
data and is not trying to execute a write instruction.. 

15, 17, 27, 26. If the other system is operating, but 
does not want to send data, and is not trying to exe- 
cute a write instruction, the subroutine ends and the 
system returns to its main program. 



2-Way System-to-System Data Transmission 

The programming involved in a 2-way system-to- 
system data transmission operation is, of necessity, 
more involved than the 1-way system-to-system pro- 
gramming just described. If both systems send and re- 
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ceive data, then the same program routine used by one 
system can also be used by the other system. 

To permit maximum efficiency, each system must 
test the status of the other system at regular intervals. 
If the data transmission operations of one system have 
priority over the other system's operations, then the 
program must include routines that will terminate, or 
delay, the other system's operations. 

If two duplicate programs are used, each program 
should include a dissimilar timing loop so that the sys- 
tems do not re-enter their routines together after ter- 
minating an operation. 

If both programs try to execute read instructions at 
the same time, both the systems stop operating because 
all program execution stops. Each system then waits 
for the other system to start sending data, but neither 
one ever starts. This condition can be eliminated by 
proper programming. 

If both programs try to execute write instructions at 
the same time, the write operations are completed, but 
neither message is transferred, resulting in the loss of 
one message in each system. This condition can be 
eliminated by proper programming. 
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Figure 1-30. 



Unacceptable Characters in Sixth Position of 
Disk Control Field 



The instruction used for the direct seek operation is 
the same as that used with normal seek operation, 
M(%F0)(BBB)R. The B-address position of the instruc- 
tion contains the core-storage address of the high-order 
position of the 6-digit disk-control field used. 



Direct Seek (1460) 

This special feature reduces access time ( 250 ms maxi- 
mum, 150 ms average) by allowing the access assembly 
to be positioned directly at a new setting without re- 
turning to the home position. 



Disk Control Field 



Alternate 
Code 



Sector 
Address 

XXXXXX 



Sector 
Count 
Field 

XXX 



XXXX#X XXX 



Remarks 



■Any Valid Digit 

-Any Valid Digit 

■ Direct Seek Code 

'Signed Difference 
(No. of Cylinders 
to be crossed Times 
2 must be signed) . 

-Drive Number 
(0, 2, 4, 6 or 8) 



Disk-Control Field 

Direct seek operations use a 6-position disk-control 
field (Figure 1-29). 

The first position of the disk-control field contains 
the disk drive number (0, 2, 4, 6, or 8). An asterisk can- 
not be used for this operation. 

The next four positions (2-5) contain a signed 4-digit 
number equal to twice the number of cylinders to be 
advanced ( + ) or retracted ( — ) . 

The sixth position contains a pound (#) sign to indi- 
cate a direct-seek operation. 

Note: Any character with 8-2-1 bit combination will be 
taken to indicate a direct seek operation and cannot, therefore, 
be used in the sixth position. See Figure 1-30 for a list of these 
characters. 

The signed difference field can be calculated by the 
method shown in Figure 1-31. This method uses the 
four high-order positions of the disk address at which 
the access arm is positioned and the four high-order 
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Figure 1-29. Disk Control Field for Direct Seek 
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Figure 1-31. Calculating Signed Difference 
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30- 
40- 
50- 
60- 

70: 

80- 

90 

99- 



Time in 
Milliseconds 



130 
137 
154 
170 
185 
202 
217 
235 
248 Maximum 



Figure 1-32. Cylinder Seek Time with Direct Seek 

positions of the disk address to be sought. Both fields 
must be changed to either odd or even ( add one to 
even, subtract one from odd ) . The old address is then 
subtracted from the new address. The result of the 
subtraction has the correct sign to indicate that the 
mechanism is to advance ( + ) or retract ( — ) . 

If for some reason the address fails to specify the 
module in the alternate code position, direct seek will 
be executed on the master file. 



Direct-Seek Timing 

Figure 1-32 provides seek times when direct seek fea- 
ture is installed on the system. 



feature. With this feature, asterisk protection, floating 
dollar sign, decimal control, and sign control left 
operations can be performed. The zero-suppression 
code in the control word should be in the position 
immediately to the left of the decimal, except as re- 
quired in Decimal Control. 

Note: Floating dollar sign and asterisk protection, or float- 
ing dollar sign and decimal control cannot be used in the same 
edit operation. When asterisk protection and decimal control 
are combined, and a blank data field is edited, the result is 
asterisks in all positions to the left of, but not including, the 
decimal-control position. 



Asterisk Protection 

When asterisks are to appear to the left of significant 
digits, the asterisk protection feature is used (Figure 
1-33 ) . The control word is written with the asterisk im- 
mediately to the left of the zero-suppression code. 
Zero balances can be protected with asterisks by plac- 
ing control zeros in the right-most position. In this 
instance, asterisks print in all positions including the 
decimal position. 



Disk-Storage Control (1460) 

This feature provides the controlling circuitry neces- 
sary for the proper operation of any ibm 1311 Disk 
Storage Drives attached to trie system. 

For more detailed information on the ibm 1311, refer 
to ibm 1311 Disk Storage Drive, Form A24-3086. 



Forward Scan; 

1. The normal editing process rjroceeds un til the aster- 
isk is sensed. 

2. The corresponding digit from the A-field replaces 
the asterisk ( in the output field ) . 

3. The editing process continues normally until the 
B-field word mark is sensed and removed. 



Disk-Storage Drive Adapter (1401) 

This feature provides the controlling circuitry to attach 
a 1311, Model 4, Disk Storage Drive to the 1401. For 
detailed information on the ibm 1311, refer to ibm 
1311 Disk Storage Drive, Form A24-3086. 



Expanded Print Edit (1401 and 1460) 

The basic operations of the move characters and edit 
instruction can be increased by the expanded print edit 



Reverse Scan: 

1. Asterisks replace zeros, blanks, and commas, to the 
left of the first significant digit. 

2. The word mark (set during the forward scan) sig- 
nals the end of editing. It is erased, and the opera- 
tion is stopped. 



A-field 




00257426 


Control word (B-field) 
Forward scan 
Reverse scan 


bbb, b*0. bb&CR 




002,574.26 CR 


**2,574.26 CR 


Results of edit 




**2,574.26CR 



Figure 1-33. Asterisk Protection 
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A-field 

Control word (B-field) 
First forward scan 
Reverse scan 
Second forward scan 
Results of edit 


00257426 
bbbb, b$0. bb 




A-field 

Control word (B-field) 
Forward scan 
Reverse scan 
Results of edit 


00378940 
CR&bbb, bbO. bb 


002,574.26 


CRb003, 789.40 


bbb 2,574.26 
$2,574;26 
$2,574.26 


CRbbb3, 789.40 
CR 3,789.40 









Figure 1-34. Floating Dollar Sign 

Floating Dollar Sign 

This feature causes the insertion of a dollar sign in the 
position at the left of the first significant digit in an 
amount field (Figure 1-34). The control word is written 
with the $ immediately to the left of the zero-suppres- 
sion code. 

Note: The control word must be larger than the A-field. 
Three scans are necessary to complete this editing operation. 

First Forward Scan: 

1. The editing proceeds until the $ is sensed. 

2. The corresponding digit from the A-field replaces 
the $ (in the output field). 

3. Editing continues until the B-field word mark is 
sensed and removed. 

Reverse Scan: 

1. Blanks replace both zeros and commas to the left 
of the first significant digit. 

2. The reverse scan continues until the word mark ( set 
during the first forward scan) signals the start of the 
second forward scan. 

Second Forward Scan: 

1. The word mark is erased, and the scan continues 
until the first blank position is sensed. This blank 
position is replaced by $, and the operation stops. 



Sign Control Left 

CR or minus symbols can be placed at the left of a 
negative field, if the sign-control-left feature is used 
(Figure 1-35). The control word is written with the 
CR or minus symbols in the high-order position. 

Forward Scan: 

1. The scan proceeds until the zero-suppression char- 
acter in the control field is sensed. 



Figure 1-35. Sign Control Left 

2. The corresponding character from the A-field is 
placed in this position of the output field. 

3. A word mark is automatically inserted in this posi- 
tion in the output field. 

4. Editing continues, and the CR or minus symbols are 
undisturbed in their corresponding positions in the 
output field, only if the sign of the A-field is minus. 
If the sign is plus, they are blanked. 

Reverse Scan: 

1. Blanks in the output field replace zeros and commas. 
The scan continues until the automatically set word 
mark is sensed. 

2. This word mark is erased and the operation ends. 

Decimal Control 

This feature ensures that decimal points print only 
when there are significant digits in the A-field ( Figure 
1-36). 



I 



1. A-field 




00000 


Control word (B-fie 
First forward scan 


Id) 


bbb. bO 


000.00 


Reverse scan 




bbb. 00 


Second forward scan 


bbb 


Results of edit 




(Blank Field) 


2. A-field 




29437 


Control word (B-field) 
First forward scan 


bbb. bO 


294.37 






* 


Reverse scan 




294.37 


Result of edit 




294.37 


3. A-field 




00001 


Control word (B-field) 
First forward scan 


bbb. bO 


000.01 






* 


Reverse scan 




bbb. 01 


Results of edit 




.01 



Figure 1-36. Decimal Control 
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Two scans are sufficient to complete this editing 
operation, unless the field contains no significant digits. 
Then three scans are required. 

First Forward Scan: 

1. When the zero-suppression code (0) is sensed dur- 
ing editing, the corresponding digit from the A-field 
replaces this position. 

2. A word mark is set automatically in this position in 
the B- (output) field. 

3. Editing continues normally until the B-field word 
mark is sensed and removed. 

Reverse Scan: 

1. Blanks in the output field replace zeros and commas 
until the decimal point is sensed. 

2. The decimal point and the digits at its right are un- 
altered. The automatically set word mark is erased. 
If there are no significant digits in the field, the sec- 
ond forward scan is initiated. Otherwise, the edit 
operation stops. 

Second Forward Scan: 

1. Blanks replace the zeros at the right of the decimal 
point and the decimal point itself. 

2. The operation stops at the decimal column. 



High-Low-Equal Compare Feature 
(1401; Standard on 1460) 

This feature expands the compare operation to include 
indicators for high, low, or equal conditions. Additional 
d-characters are included so that the branch if indi- 
cator on instruction can test for these conditions. The 
basic machine permits testing for unequal conditions 
only. 

This feature is standard on the ibm 1460 Data Proc- 
essing System. 



Autocoder 


d-character 


BE 


S 


BL 


T 


BH 


U 



Function. This instruction tests the compare indicator 
for the result of the previous compare operation and 
branches to the I-address, if the condition specified 
by the d-character is present: 



Branch to I-address if: 
B = A (B equals A) 
B < A ( B is less than A ) 
B > A ( B is greater than A ) 



If the condition is not present, the program con- 
tinues with the next sequential instruction. 

Word Marks. Word marks are not affected. 

Timing. 
No branch: 

T = N (Lj + 1) ms. 

Branch (ivithout indexing): 

T = N (L : + l) ms. 

Branch (with indexing): 

T = N (Li + 2) ms. 

Address Registers After Operation. 



No Branch 
Branch (without 

indexing ) 
Branch (with 

indexing ) 



I- Add. Reg. 
NSI 

NSI 

NSI 



A- Add. Reg. 
BI 

BI 

BI 



B-Add. Reg. 
dbb 

Blank 

NSI 



Example. Compare the data at RECNO (0596) to the 
control number at CONTNO (0495). If the data at 
RECNO is higher than the control number at 
CONTNO, branch to GRTAN (0797) for the next 
instruction (Figure 1-37). 



SPS 



LINE 


COUNT 


LABEL 
8 13 


OPERATION 


(A) OPERAND 


(BI OPERAND 


d 


ADDRESS - 


| 


M • 400flESS fj *.""' 


| 


0,1,0 







(?, ! 


(?,to.N,T,tJ,Oi ! , , 




RECU.O, ',',,, 




U 


0,2,0 







ft : 


G,ST,A,N, ! ! , , 







Autocoder 



Branch if High, Low, or Equal Compare 



Instruction Format. 



Mnemonic 


Op Code 


I-address 


d-character 


SPS B 

A see chart 


JB 


XXX 


X 



Label 

• 15 


Operation 

IS 20 


OPERAND 

21 26 }0 36 40 45 SO 


1 


e. . . . 


CO.H.TN.O.ye.ECjJ.0, 


i 



B.H. . . 


SRT.M 



Assembled Instruction: C 495 596 
B 797 U 

Figure 1-37. Branch if High Compare 
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Indexing and Store Address Register (1460) 



The indexing-and-store-address-register special feature 
for the 1460 functions exactly the same as the index- 
ing-and-store-address-register portions of the advanced- 
programming special feature for the 1401. For detailed 
information on indexing-and-store-address-register op- 
eration, refer to the appropriate sections of the Ad- 
vanced Programming special feature write-up in this 
publication. Replace 1401 timing (.0115) with 1460 
timing (.006). 



Multiply-Divide (1401, 1460) 

This feature makes it possible to perform direct multi- 
plication and division in the ibm 1401 and/or 1460 
Data Processing Systems. 



Multiply 

Instruction Format. 

Mnemonic Op Code 



A-address 



B -address 



Function. The multiplicand (data located in the A- 
field) is repetitively added to itself in the B-field. 
The B-field contains the multiplier in the high-order 
positions, and enough additional positions (low 
order) to allow for the development of the product. 
At the end of the multiply operation, the units posi- 
tion of the product is located at the B-address. The 
multiplier is destroyed in the B-field as the product 
is developed. Therefore, if the multiplier is needed 
for subsequent operations, it must be retained in an- 
other storage area. 

The multiply-divide feature for the 1460 system 
has additional circuitry that automatically eliminates 
readdressing machine cycles when recomplementing 
is required during the operation. 



Rules: 

1. The product is developed in the B-field. The 
length of the B-field is determined by adding "1" to 
the sum of the number of digits in the multiplicand 
and multiplier fields. 



Example: 

1246 

X 543 



+ 



4-digit multiplicand 
3-digit multiplier 
1 



8 positions must be allowed in the B-field 

2. A word mark must be associated with the high- 
order positions of both the multiplier and multipli- 
cand fields. 

3. A- and B-bits need not be present in the units 
positions of the multiplier and multiplicand fields. 
The absence of zone bits in these positions indicates 
a positive sign. At the completion of the multiply 
operation, the B-field will have zone bits in the units 
position of the product only. The multiply operation 
uses algebraic sign control (Figure 1-38). 

4. Zone bits that appear in the multiplicand field are 
undisturbed by the multiply operation. Zone bits 
in the units position of the multiplicand are inter- 
preted for sign control. 

Timing. The average time required for a multiply op- 
eration is: 

T = N (Li + 3 + 2L + 5L c Lm + 7L M ) ms. 
L c = length of multiplicand field. 
Lw— length of multiplier field. 

A chart of approximate timings is included in the 
section on Timing. 

Note. The first addition within the multiply operation inserts 
zeros in the product field from the storage location specified 
by the B-address up to the units position of the multiplier. 

The A-address register and the B-address register indicate 
positions within the A- and B-fields on which operations are 
currently being performed. 

Word Marks. A word mark must be associated with 
the high-order positions of the multiplier and multi- 
plicand fields. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
A minus the length 
of the multiplicand. 



B-Add. Reg. 

B minus the length 

of product field. 



Multiplier Sign 


+ 


+ 


- 


- 


Multiplicand Sign 


+ 


- 


+ 


- 


Sign of Product 


+ 


- 


- 


+ 



Figure 1-38. Algebraic Sign Control for Multiplication 
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Example. Multiply: 





Location of 


Contents of 




Label 


Data Word 


Data Word 


Description 


MULCAN 


0502 


1246 


Multiplicand 


MULIER 


0065 


543 


Multiplier 


PRODCT 


0610 




Product 



The size of the product field is 4 + 3 + 1 = 8. The 
multiplier is placed in the three high-order positions 
of the PRODCT area (0603, 0604, and 0605). At 
the completion of the multiply operation, load the 
product in the area labeled OUT2 (0178). The units 
positions of the multiplier and multiplicand fields 
may be signed (Figure 1-39). 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


(A) OPERAND 


(Bl OPERAND 


d 


ADDRESS - ' 


i 


ADDRESS |±| ™*"' 


3S 


0,1,0 


, 




za! 


M.U.U.J ER! ! , , 




PfiO,D.C.T\-\ , 3 


~ 


— 


0,2,0 




, , , , , 


m, : 


M,U.L,C,AM! 1 , , 




P,RA0,C,T! ! , , 


0,3,0 






U,C\P> 


rr&dct: i , 




0,U,-TT2., ',!!,, 



Autocoder 



Label 



Operation 
22 



£A_ 



nuwA 



OPERAND 
_45 38 



ku l i ,£/?. PJiopar-K 



ft . . . H. ULCAt4..P.R.0.l>C7. 



P & D M .T. i O VJZ , 



Assembled Instruction: _?_ 065 605 
@ 502 610 
L" 610 178 



Figure 1-39. Multiply 



Divide 

Instruction Format. 

Mnemonic Op Code 

D % 



A-address 
xxx 



B-address 
xxx 



Function. This instruction divides the data (dividend) 
in the low-order positions of the B-field by the divisor 
located in the A-field, and develops the quotient in 
the high-order positions of the B-field. The remain- 
der is left in the low-order positions of the B-field. 

Rules: 

1. The quotient is developed in the B-field. The 
length of the B-field is determined by adding 1 to 
the sum of the number of digits in the divisor and 
dividend fields. 



Example: 



543 



1246 



4 digit dividend 
3 digit divisor 

+ 1 

8 positions must be 
allowed in the B-field 



Divisor Sign 


+ 


+ 


- 


- 


Dividend Sign 


+ 


- 


+ 


- 


Quotient Sign 


+ 


- 


- 


+ 


Remainder Sign 


+ 


- 


+ 


- 



Figure 1-40. Algebraic Sign Control for Division 



2. A word mark must be associated with the high- 
order position of the A-field. 

3. In all cases A- and B-bits (plus sign) or B-bit 
(minus sign) must appear in the units position of the 
dividend field. The divisor may be either signed or 
unsigned. If there are no bits in the units position of 
the divisor, the machine assumes the divisor factor is 
positive. The divide operation uses algebraic sign 
control (Figure 1-40). 

4. The dividend is loaded in the low-order positions 
of the B-field ( Figure 1-41 ) by a zero and add in- 
struction to ensure that zeros are present in the high- 
order positions of the B-field. 

5. The B-address in the divide instruction specifies 
the high-order position of the dividend. 

At the completion of division: 

a. The quotient is in the high-order positions of the B-field. 
The location of the units position of the quotient, is the ad- 
dress of the units position of the dividend, minus the length 
of the divisor, minus one. 

b. The remainder is in low-order positions of the B-field. 

c. The sign of the quotient is over the units position of the 
quotient field. 

d. Because only one quotient digit can be developed at a 
time, it is important to address the high-order position of the 
dividend (B-address of the divide instruction). This ensures 
that the first divide operation will result in a single high- 
order quotient digit. A dividend improperly addressed can 
cause an arithmetic overflow if the result of the first divide 
operation is greater than 9. 

Word Marks. A word mark must define the high- 
order position of the divisor. 

Timing. Average time required for the execution of a 
divide operation is calculated: 

T = N (Li + 2 + 7L R L Q + 8L Q ) ms. 
Lq = length of the quotient field. 
L R = length of the divisor field. 



Dividend 

ooooxxxx 



Figure 1-41. Dividend in B-field 
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± ± 

XXXX XXX 

Quotient Remainder 
B-FIELD 



Figure 1-42. Location of the Results of a Divide Operation 



A chart of approximate timings is included in the 
section on Timing. 



Note. A divide operation refers to the process of developing 
each quotient digit. If the quotient field is not large enough, 
no overflow is indicated. This is a programming error for 
which the machine does not check. Division by zero results 
in an arithmetic overflow condition. Figure 1-42 shows the 
result of a divide operation. 

Extra zeros can be added to the dividend prior to a divide 
operation when a larger quotient is required. For each addi- 
tional quotient digit desired, place one zero to the right of 
the dividend as shown in Figure 1-43. Note that in this exam- 
ple, the units position of the quotient is not located in the 
position previously described in the section At The Comple- 
tion of Division, a. 

The quotient field is not cleared before actual division 
begins. 



Address Registers After Operation. 



1-Add. Reg. 

NSI 



A-Add. Reg. 

A minus the length 

of the divisor. 



B-Add. Reg. 
Tens position of quo- 
tient. If divisor has all 
zeros, the B-address 
register stands at the 
units position of the 
dividend minus the 
length of the divisor 
minus the length of 
the dividend minus 1. 



Regular 








0001 




Quotient 


1234 


1234 




0001 

+ 
000001234 










Dividend 


1234 Divisor 


Additional Quotient 






digits desired. 






0001. 


000 


Quotient 


1234 


1234. 


000 


0001.000 

■+■ 










000001234.000 






Dividend 






1234 Divisor 



I 



Figure 1-43. Additional Quotient Digits 
Example. DIVIDE (Figure 1-44). 



Label 


Location of 








Data Word 


Data Word 


Description 


DIVEND 


0502 


1246 


Dividend 


DIVSOR 


0065 


543 


Divisor 


QUOT 


0985 




Quotient 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


l«l OPERAND 


(§) OPERAND 


d 


ADDRESS ± CH *' , • 
17 J _ 3 | ADJ. 


i 


ADDftESS ± CHAR - 
2t L4I * DJ ' 


= 


0,1,0 


, 


, , , , 


ztf! 


£>,l V,f,/V,P! ! , , 




QU.O.T, , ! ! , . 






0,^,0 


, 




r>, : 


f>,l ,V,5vO,«.l ! , , 




4uorr ,1-! ,3 



Autocoder 



Label 



Operation 



ZA_ 



t>,l \)EN.0. ? <$>an.T 



. i . , ,fft . . . fhi.v.c;At?. r (ft).o.T.-.3 



Assembled Instruction: 7_ 502 985 
% 065 982 



Figure 1-44. Division 



1401 MULTIPLY TIMES* WITH 


SPECIAL 


FEATURE 














1 


2 


3 


4 


5 


6 


-7 


8 


9 


10 


11 




' 


Number Positions Multiplier 


1 


.276 


.347 


.418 


.489 


.560 


.631 


.702 


.773 


.844 


.915 


.986 




2 


.414 


.552 


.690 


.828 


.966 


1.104 


1.242 


1.380 


1.518 


1.656 


1.794 






3 


.552 


.748 


.944 


1.140 


1.336 


1.532 


1.728 


1.924 


2.120 


2.316 


2.512 


' 


' 


4 


.690 


.943 


1.196 


1.449 


1.703 


1.956 


2.209 


2.462 


2.715 


2.968 


3.221 




5 


.828 


1.139 


1.450 


1.761 


2.072 


2.383 


2.694 


3.005 


3.316 


3.627 


3.938 




6 


.966 


1.334 


1.702 


2.070 


2.438 


2.806 


3.174 


3.542 


3.910 


4.278 


4.646 




7 


1.104 


1.530 


1.956 


2.382 


2.808 


3.234 


3.660 


4.086 


4.512 


4.938 


5.364 




8 


1.242 


1.725 


2.208 


2.691 


3.174 


3.657 


4.140 


4.623 


5.106 


5.589 


6.072 




9 


1.380 


1.921 


2.462 


3.003 


3.544 


4.085 


4.626 


5.167 


5.708 


6.249 


6.790 




10 


1.518 


2.116 


2.714 


3.312 


3.910 


4.508 


5.106 


5.704 


6.302 


6.900 


7.498 


* Multiply 1401 Times by Factor of .522 for 1460 Times 



Figure 1-45. ibm 1401 and 1460 Multiply Times (with Special Feature) 
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Multiply and Divide Timing 

The four timing charts give the approximate timings 
of multiply (Figures 1-45 and. 1-46) and divide (Figures 
1-47 and 1-48) operations. Two of the charts are based 
on the timings when a subroutine written in actual 
language is used. The other two charts are based on 
the timings requinxl when the system is equipped with 
the special feature? for multiply and divide. 



Multiply and Divide Subroutines 

These are subroutines for multiply and divide opera- 
tions, discussed here to illustrate programming meth- 
ods and to aid programming for machines not equipped 
with the multiply-divide special feature. These are not 
the only methods of performing these operations— they 
are typical methods. 







1401 MULTIPLY TIMES* BASED ON MULTIPLY 


SUBROUTINE 










No. Pos. Multiplicand 




1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


} 


Number Positions Multiplier 


1 


3.51 


3.63 


3.74 


3.86 


3.97 


4.08 


4.20 


4.32 


4.43 


4.55 


4.67 


Value of each 




2 


7.10 


7.33 


7.56 


7.79 


8.02 


8.25 


8.48 


8.71 


8.94 


9.17 


9.40 


Multiplier Digit > 


* 


3 


10.74 


11.08 


11.43 


11.77 


12.12 


12.46 


12.81 


13.15 


13.50 


13.84 


14.19 


assumed to be an 


4 


14.42 


14.88 


15.34 


15.80 


16.26 


16.72 


17.18 


17.64 


18.10 


18.56 


19.02 


average of "5" 


5 


18.15 


18.73 


19.30 


19.88 


20.45 


21.03 


21.60 


22.18 


22.75 


23.33 


23.90 




6 


21.93 


22.62 


23.31 


24.00 


24.69 


25.38 


26.07 


26.76 


27.45 


28.14 


28.83 




7 


25.76 


26.57 


27.37 


28.18 


28.98 


29.79 


30.59 


31.40 


32.20 


33.01 


33.81 




8 


29.63 


30.55 


31.47 


32.39 


33.31 


34.23 


35.15 


36.07 


36.99 


37.91 


38.83 




9 


33.54 


34.58 


35.61 


36.65 


37.68 


38.72 


39.75 


40.79 


41.82 


42.86 


43.89 


(Add 1ms to times shown abovt 


> if sign 


ing of quotient is req 


uired) 


















* Multiply 1401 Times by Factor 


of .522 


for 1460 Times 





















Figure 1-46. ibm 1401 and 1460 Multiply Times (based on Multiply Subroutine) 







1401 DIVIDE TIMES* WITH 


SPECIAL FEATURE 










No. of Pos. in Quotient 




1 


2 


3 


4 


5 


6 


7 


8 


9 


10 




No. of Pos. in Divisor 


1 


.276 


.449 


.621 


.794 


.966 


1.139 


1.311 


1.484 


1.656 


1.829 






2 


.357 


.610 


.863 


1.116 


1.369 


1.622 


1.875 


2.128 


2.381 


2.634 






3 


.438 


.771 


1.104 


1.437 


1.770 


2.103 


2.436 


2.769 


3.102 


3.435 


▼ 


4 


.518 


.932 


1.346 


1.760 


2.174 


2.588 


3.002 


3.416 


3.830 


4.244 




5 


.598 


1.093 


1.588 


2.083 


2.578 


3.073 


3.568 


4.063 


4.558 


5.053 




6 


.679 


1.254 


1.829 


2.404 


2.979 


3.554 


4.129 


4.704 


5.279 


5.854 




7 


.759 


1.415 


2.071 


2.727 


3.383 


4.039 


4.695 


5.351 


6.007 


6.663 




8 


.840 


1.576 


2.312 


3.048 


3.784 


4.520 


5.256 


5.992 


6.728 


7.464 




9 


.920 


1.737 


2.553 


3.370 


4.186 


5.003 


5.819 


6.636 


7.452 


8.269 




10 


1.001 


1.898 


2.795 


3.692 


4.589 


5.486 


6.383 


7.280 


8.177 


9.074 


* Multiply 1401 Times by Factor of 


.522 for 14 


60 Times 



















Figure 1-47. ibm 1401 and 1460 Divide Times (with Special Feature ) 
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1401 DIVIDE 


TIMES* BASED ON 


DIVIDE SUBROUTINE 










No. of Po$. in Quotient 




1 


2 


3 


4 


5 


6 


7 


8 


9 


10 




No. of Pot. in Divisor 


1 


8.502 


13.703 


18.904 


22.762 


26.41 1 


30.060 


33.709 


37.358 


41.007 


44.656 






2 


8.870 


13.899 


18.928 


22.909 


26.730 


30.551 


34.372 


38.193 


42.014 


45.835 






3 


9.238 


14.094 


18.950 


23.060 


27.054 


31.048 


35.042 


39.036 


43.030 


47.024 


Value of each ▼ 


4 


9.606 


14.290 


18.974 


23.208 


27.374 


31.540 


35.706 


39.872 


44.038 


48.204 


Quotient Digit as- 


5 


9.974 


14.485 


18.996 


23.359 


27.698 


321037 


36.376 


40.715 


45.054 


49.393 


sumed to be an 


6 


10.342 


14.681 


19.020 


23.507 


28.018 


32.529 


37.040 


41.551 


46.062 


50.573 


average of 


7 


10.710 


14.876 


19.042 


23.658 


28.342 


33.026 


37.710 


42.394 


47.078 


51.762 


"5" 


8 


11.078 


15.072 


19.066 


23.806 


28.662 


33.518 


38.374 


43.230 


48.086 


52.942 




9 


11.446 


15.267 


19.088 


23.957 


28.986 


34.015 


39.044 


44.073 


49.102 


54.131 




10 


11.815 


15.468 


19.113 


24.105 


29.306 


34.507 


39.708 


44.909 


50.110 


55.311 


(Add 1ms to times shown above i1 


signing of 


quotient is 


required) 
















* Multiply 1401 Times by Factor o 


F .522 for 1460 Times 



















Figure 1-48. n»M 1401 and 1460 Divide Times (baaed on Divide Subroutine) 
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Figure 1-49. 
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I 1 

I Branch | 

I To 

I Main Routine 



Multiply Flow Chart 



Branch 
Unconditional 
To Zero Test 




Figure 1-50. Multiply Subroutine (actual) 



I 



Multiply Subroutine 

The block diagram in Figure 1-49 illustrates the logic 
used in developing the two multiply subroutines dis- 
cussed here. Both subroutines provide for a maximum 
of a 9-digit multiplier, 11-digit multiplicand, and a 20- 
digit product. Both routines use positive factors. 

The subroutine written in actual language (Figure 
1-50) occupies the 900 block of storage. A multiplier 
area is provided in storage positions 901-909, and the 
product area is assigned in storage positions 910-929. 
The multiplicand can be located anywhere. 
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Figure I-5I. Multiply Subroutine (Symbolic) 



Any program that uses this subroutine must include 
a step that moves the multiplier address (XXX) to loca- 
tion 937 and the multiplicand address (YYY) to loca- 
tion 952. 

At the completion of the multiply subroutine, the 
program instruction step 12 can use a branch to the 
main program or stop instruction. 

The routine starts in storage position 930. The prod- 
uct is found in 929 for a 9 -digit multipler, 928 for 
8-digit, 927 for 7-digit, 926 for 6-digit, etc. 

The subroutine written using the symbolic program- 
ming system ( Figure 1-51 ) parallels the one written in 
actual. In this instance, the 1401 (through the proc- 
essor program) controls the location of the instruc- 
tions, and the data and work areas. 

Note: The multiply subroutine results in blanks instead of 
zeros in the low-order position of a product when the multiplier 
contains low-order zeros. To correct this situation, set the prod- 
uct area to zeros. 



Divide Subroutine 

The restrictions placed on this subroutine (Figures 1-52 
and 1-53) are: 



1. The dividend and quotient fields must be of equal 
length. 

2. The dividend and divisor must both be positive. 

3. The divisor must have no zone for its positive indi- 
cation. This is necessary only if the divisor could 
be zero. 

4. The divisor cannot contain more than nine leading 
zeros. 

5. All fields must be located completely below ad- 
dress 999. 

6. At the completion of the subroutine, the address of 
the units position of the quotient can be found in 
the B -address of the instruction located in 651. 

7. The remainder is left in the dividend field. 

8. A word mark must be located immediately to the 
right of the units position of the dividend. 

9. The quotient area must be preset to zeros or blanks 
to develop the correct quotient. If the area is not 
zeroed or blanked, then the quotient will be added 
to whatever is there. The positions added will de- 
pend on the number of leading zeros in the divisor. 
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Figure 1-52. Divide Flow Chart 



10. The information shown in Data for Division Sub- 
routine (Figure 1-53), except the constant 1 in 
location 513, must be set initially for each desired 
execution of the divide subroutine. The two ad- 
dresses in locations 507 and 510, associated with 
the divisor, are not altered. Thus, they do not have 
to be reinitialized if the divisor is contained in the 
same area. 



Numerical Print Control (1401, 1460) 

This feature is required when the numerical-print spe- 
cial feature is installed on the ibm 1403 Printer (Models 
1 or 2 on 1401; Model 2 on 1460). This feature provides 
the checking circuitry necessary for the operation of 
the numerical-print special feature. For detailed infor- 
mation on this feature, refer to the ibm 1403 Printer, 
Form A24-3073. 



Print Control (1401) 

This feature controls the additional 32 print positions 
of the ibm 1404 Printer, which includes the storage and 
checking circuitry when used with the 1401 only. 



Print Control, Additional (1401) 

This feature controls the additional 32 print positions 
of the ibm 1403 Printer, Model 2, attached to a 1401, 
and includes the storage and checking circuitry. For 
detailed information on the 1403, Model 2, refer to 
the ibm 1403 Printer, Form A24-3073. 



Print Storage (1401, 1460) 

This special feature provides 100 or 132 non-address- 
able extra positions of core storage on the 1401 (132 
positions are standard on the 1460 ) . They are used as 
temporary storage for printer output data. 

When this feature is installed, the write line in- 
struction transfers the data in the printer area ( storage 
location 201-332) to print storage. Two milliseconds 
after the write line instruction is given, the normal 
printer interlock is released and processing can con- 
tinue. Thus, available processing time during a 100-ms 
cycle is 98 ms, as opposed to the 16-ms processing time 
available when the machine is not equipped with print 
storage. The print-storage area interlocks for 84 ms 
during printing on 1401 system. Therefore, another 
write line instruction given during this 84 ms will 
cause the program to stop until the interlock is re- 
leased. 
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Step 
No. 


Inst. 
Address 


Instruction 


Remarks 


Effective No. 
of Characters 






O 
P 






A/I 


B 


d 


Inst. 


Data 


Total 






516 


M 


507 


529 




Store Address of Word Mark Position 
(High Order ) of Divisor 












523 


B 


662 


YYY 





Branch if Divisor Digit Equals Zero 












531 


S 


512 


515 
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(Number of High 
(Length of Divisor) - Order Zeros) 
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A 
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Adjust Dividend Address 
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A 
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Modify Addresses 
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501 
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S 
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Y 
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Clear zone from low-order position to 
prepare for address assignment. 
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Clear zone from low-order position to 
prepare for address assignment. 
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Divide 
Set Modified Addresses into Routine 












587 


M 
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DATA FOR DIVISION SUBROUTINE 
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Data Word Data Word DESCRIPTION OF DATA 
501 WWW Address of word mark position 

order) of dividend 
504 XXX Address of word mark position 

order) of quotient 
507 YYY Address of word mark positi 

divisor 
510 ZZZ Divisor Address 

512 00 Counter for number of zeros 

divisor 

513 1 Constant 

515 NN Length of the divisor 
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on of 

in 
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Figure 1-53. Divide Subroutine 
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With this feature, two indicators can be tested by 
the branch if indicator on instruction, B(xxx)d. 

The print-storage-busy indicator turns on during the 
first 83% ms of the print cycle. The d-character P tests 
the indicator. If it is on, the program branches; if it is 
off, the next sequential program step is taken. 

The printer-error indicator (d-character of 4=) should 
not be tested until the program has determined that the 
print-storage-busy indicator is off. If the error indi- 
cator is tested before the busy indicator turns off, the 
system interlocks until the print-storage operation in 
process is completed. 

The carriage-busy indicator turns on during form- 
movement time. The d-character R tests this indicator. 
If it is on, the program branches; if it is off, the next 
sequential program step is taken. 

On a 1460 system die print-storage feature provides 
a storage medium so that nearly all of the normal inter- 
lock time is released during printing (99 ms of process- 
ing time released for each 100-ms print cycle). There- 
fore, processing time is greatly increased for applica- 
tions characterized by high printing requirements. 



Programming Considerations 

When the print-storage special feature is installed, an 
improperly placed branch if carriage channel #9 
(or #12) instruction can cause incorrect carriage over- 
flow operation on the 1403. 

On a system equipped with print storage, the system 
is interlocked for only 2 ms during the 100-ms print 
cycle. The system is then free to continue processing 
for the rest of the print cycle. Because of this, it is pos- 
sible to execute a branch if carriage channel #9 (or 
#12) instruction during this additional processing time. 
If this instruction is executed before the print opera- 
tion is completed, the instruction actually checks for a 
channel 9 or 12 hole too soon. 

When the print operation that spaces the carriage 
tape to a channel 9 or 12 finally takes place, the chan- 
nel 9 or 12 hole will not be checked for until the next 
print operation is under way. This condition results in 
printing an extra line before the carriage overflow 
operation occurs. 
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Printer (1404) Adapter (1401) 

This feature provides the controls and checking cir- 
cuitry necessary to attach a 1404 printer to the ibm 
1401. 



Printer Adapter — 1403, Model 3 (1460) 

This feature provides the circuitry necessary for attach- 
ing and controlling an ibm 1403 Printer, Model 3, on a 
1460 system. 



Printer Control Adapter — 
Second Printer (1460) 

This feature provides the circuitry necessary to attach 
the first ibm 1462 Printer Control Unit and its associ- 
ated 1403 printer to the 1460 system. 



Processing Overlap (1401, 1460) 

The processing-overlap special feature for the ibm 
1401 and/or 1460 Data Processing Systems provides, 
for many applications, great reductions in over-all job 
time. The high-speed processing and input-output abil- 
ities of the 1401 and 1460 now can be used with maxi- 
mum efficiency. Jobs requiring extensive input-output 
operations and lengthy programming now can be per- 
formed at or near maximum speeds. The actual increase 
in efficiency and consequent saving in job time varies 
with the specific program, and depends on the input- 
output requirements of the particular application. 

The processing-overlap feature allows processing to 
be interrupted in order to take input-output cycles. A 
character can be read, written, or punched between 
processing cycles. 

Serial input-output devices used with the ibm 1401 
and/or 1460 systems, such as the ibm 1011 Paper Tape 
Reader and the ibm 1419 Magnetic Character Reader, 
can have their operations performed in overlap mode. 
In some cases, entire input-output operations can be 
overlapped; in others, partial overlapping can occur. 



Job time required for card input-output applications 
is reduced because the processing operation is not 
interlocked during card reading or punching. This is 
also true when reading or writing magnetic tape. Tape 
operations and processing can occur on alternate cycles. 
This ability can result in appreciable increase in job 
time economy. 

The processing-overlap special feature makes the 
ibm 1401 and 1460 Data Processing Systems more pow- 
erful tools for use in the field of data processing. 

Note: On 1460 systems equipped with this feature and the 
ibm 1448 Transmission Control Unit, processing overlap cannot 
be used in any program that also uses the 1448. 



Data Flow 

The overlap special feature requires the addition of an 
O-register and an O ( overlap ) -address register to the 
processing unit ( Figure 1-54 ) . These registers function 
in much the same manner as the A- and B-registers 
and the I-, A-, and B-address registers. That is, the 
O-register is used for movement of data when operat- 
ing with an I/O unit. The O-address register is used 
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B- Address 
Register 
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Register 



Figure 1-54. ibm 1401 and 1460 Processing Overlap Data Flow 
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to keep track of the location of data that is moved by 
an I/O operation. These registers, when used by the 
program, operate on alternate cycles with the normal 
registers. Thus the 1401 takes processing cycles and 
then an input-output cycle, when required, instead of 
interlocking processing while an input-output opera- 
tion is being performed. This means a savings in over- 
all job time. 



IBM 1402 Card Read-Punch (Model 1 on 1401; 
Model 3 on 1460) 

When the system is in the overlap mode, processing 
can occur during the card cycle in which data is read 
from, or punched into, a card. Processing does not 
occur during the time used for either read or punch 
scanning, but alternates with scanning. 

At the beginning of each read or punch scan, the 
character in the A-register is sent to the O-register 
(Figure 1-55) and the O-address register is set at the 
column being scanned. When the read or punch scan 
of the character is completed, the character in the 
O-register is sent back to the A-register. At this point 
processing resumes. 



Tape Operations 

During a read operation, data from magnetic tape en- 
ters the A-register and then moves into core storage. 
During an overlap-read operation, data necessary for 
processing is contained in the A-register. In order to 
save the data, it is sent to the O-register until recalled 
for the next processing cycle, before data is read in 
from tape to the A-register (Figure 1-56). The O-ad- 
dress register contains the storage address in which the 
data being read from magnetic tape is to be stored at 
the same time that the I-, A-, and B-address registers 
keep track of the processing operation being per- 
formed 

During a write operation, data from core storage 
passes throught the B-register and enters the O-regis- 
ter ( Figure 1-57 ) . It is sent to magnetic tape from the 
O-register. Processing cycles use the A- and B-register. 
The O-address register contains the storage address of 
the data being written on magnetic tape. At the same 
time the I-, A-, and B-address registers keep track of 
the processing operation being performed. 
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Figure 1-56. Overlapped Magnetic-Tape Read Operation 

To store the contents of the O-address register at 
the end of an overlapped tape operation the following 
operations must be performed: 



B (xxx) J 



Then 
H xxx 



BRANCH IF TAPE BUSY INDICATOR ON. 

This instruction allows the contents of the 
O-address register to be transferred to the 
B-address register (with the advanced-pro- 
gramming feature) if the indicator is not on. 

Store B-address register 



Other Input-Output Units 

Input-output units such as the ibm 1419 Magnetic 
Character Reader, when operating in the overlap 
mode, function in the same manner as a magnetic- 
tape unit. Overlapping and processing occurs just as 
if the operation were a tape read or write operation. 



Processing-Overlap Instructions 

To signal the system that an operation to be performed 
should be done in the overlap mode, special instructions 
and A-address changes must be used in the program. 

A-Address 

The A-address hundreds position of a tape or input- 
output unit (not 1405 or 1407) instruction is changed 
from % to @. The @ (at) symbol signals the process- 
ing unit that the operation to be performed should be 
done as an overlap operation. The @ symbol can be 
used to signal an overlap operation with the: 

ibm 1011 Paper Tape Reader 

ibm 1419 Magnetic Character Reader 

ibm 729 ii, iv, v, vi Magnetic Tape Unit 

ibm 7330 Magnetic Tape Unit 
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Figure 1-55. ibm 1402 Overlap Operation 
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Figure 1-57. Overlapped Magnetic-Tape Write Operation 



Overlap On 

Instruction Format. 

Mnemonic 

SS 



Op Code 
K 



d-character 



Function. This instruction sets the system processing 
unit in the overlap mode. All 1402 read, punch, and 
combination card instructions that follow this in- 
struction in the program are performed in the over- 
lap mode. 

Word Marks. Word marks are not affected. 

Timing. T=N (Li + l)ms. 



Address Registers After Operation. 



1-Add. Reg. 

NSI 



A-Add. Reg. 
Abb 



B-Add. Reg. 
Abb 



Example. Set the system in the overlap mode (Figure 

1-58). 
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Assembled Instruction: K $ 
Figure 1-58. Overlap On 



Overlap On and Branch 

Instruction Format. 

Mnemonic Op Code I-address d-character 

SPS SS JK xxx $ 

A SSB 

Function. This is the same as overlap on, except that 
the next instruction is taken from the I-address. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms. 



Address Registers After Operation. 



1-Add. Reg. 
NSI 



A-Add. Reg. 
BI 



B-Add. Reg. 
dbb 



Example. Set the system in the overlap mode and 
branch to CDROUT (0950) for the next instruction 
(Figure 1-59). 



SPS 



LINE 


COUNT 


LABEL 

• 13 


OPERATION 


(A) OPERAND 


IB) OPERAND 


d 


ADDRESS 1 "*"• 


I 


ADDRESS ± CH *"' 


U 


0,1,0 


, 





9£! 


C,P,(?,o,O.T! : , , 




.....!!.. 




$ 



Autocoder 



Label Operation 
IS '»!'« ZSJZJ 8fi_ 



OPERAND 



. B.Sfl ICDRO.lVf J $ 



Assembled Instruction: K 950 $ 



Figure 1-59. Overlap On and Branch 



Overlap Off 

Instruction Format. 

Mnemonic 
SS 



Op Code 
K 



d-character 



Function. This instruction returns the system process- 
ing unit to normal operation. All card input-output 
instructions following this instruction are performed 
without the overlap feature. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms. 

Address Registers After Operation. 



1-Add. Reg. 
NSI 



A-Add. Reg. 
Abb 



B-Add. Reg. 
Abb 



Example. Place the system in normal operation (Fig- 
ure 1-60). 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


(Al OPERAND 


(BI OPERAND 


d 


ADDRESS t C ( [J i *"- 


tl 


ADDRESS ± CM *"' 
„ l„l «"• 


M 


0,1,0 


, 


,,,,, 


f?S! 


i,ii,i',i 




Ill, 




* 



Autocoder 


















Label 

6 


15 


Operation 

16 20 


21 


25 


30 


35 


40 


OPERAND 

45 50 


* 1 
1 . . . 


S.S . , 


»,,,.,, 



Assembled Instruction: K • 
Figure 1-60. Overlap Off 
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Overlap Off and Branch 



Address Registers After Operation. 



Instruction Format. 



Mnemonic 


Op Code 


I-address 


d-character 


SPS SS 


K 


XXX 


• 


A SSB 









Function. This instruction is the same as overlap off, 
except that the next instruction is taken from the 
I-address. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms. 

Address Registers After Operation. 



1-Add. Reg. 
NSI 



A-Add. Reg. 
BI 



B-Add. Reg. 
Abb 



1-Add. Reg. 
NSI 



A-Add. Reg. 
Abb 



B-Add. Reg. 
Abb 



Example. Reset overlap mode and return the system to 
normal operation (Figure 1-62). 



SPS 



UIIE 
3 ft 


COUNT 


LAtEL 


OPERATION 


(«> OPERAND 


(BI OPCfiANO 


d 


AOORESS + "*"■ 


% 


ADDRESS ± CH *"' 

II ADJ. 


M 


, 1 i 






as 


! ! , , 




i i i i i 1 1 i i 




w 



Autocoder 


















Label 

6 


13 


Operation 

IS 20 21 


25 


SO 


36 


40 


OPERAND 

45 50 


1 


SS . , 


K 



Assembled Instruction: K □ 



Figure 1-62. Reset Overlap 



Example. Place the system in normal operation, and 
branch to the routine labeled NORCRD ( 1771 ) for 
the next instruction (Figure 1-61). 



SPS 



LIKE 


COUNT 


UIEL 
• 19 


OPERATION 


(A) OPERAND 


(•I OPERAND 


d 
» 


ADDRESS ± 'I**' 


it 


ADDRESS ± '^ 




, ><i 


, 




s,$\ 


N.O.R.C.RM 1 . . 




! ! , , 




• 



Autocoder 



Label bperatlonl OPERAND 
i '» '» tfiU U 2fi 55 4fl ii Bfi 



I . . . isgfl . woRcm,.. 

Assembled Instruction: K X71 • 
Figure 1-61. Overlap Off and Branch 



Reset Overlap 



Instruction Format. 

Mnemonic 
SS 



Op Code 
K 



d-character 

□ 



Function. This instruction is operative only when the 
serial input-output adapter special feature is in- 
stalled. If the system is performing an overlapped 
serial I/O operation when this instruction is given, 
the I/O device is disconnected from the system. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms. 

Note. If an overlap magnetic-tape operation is in process when 
this instruction is given, the tape unit is disconnected and the 
tape transmission error indicator is turned on. 



Reset Overlap and Branch 

Instruction Format. 

Mnemonic Op Code I-address d-character 

SPS SS K xxx □ 

A SSB ~ 

Function. This instruction is the same as reset over- 
lap, except that the next instruction is taken from 
the I-address. 

Word Marks. Word marks are not affected. 

Timing. T = N ( L r + 1 ) ms. 



Address Registers After Operation. 



1-Add. Reg. 
NSI 



A-Add. Reg. 
BI 



B-Add. Reg. 
Abb 



Example. Reset overlap mode and branch to routine 
labeled NORMOP (1755) for the next operation (Fig- 
ure 1-63). 



SPS 



3 B 


COUNT 


UBEL 
t IS 


OPEMTIM 


(» OPERAND 


(■1 OPERAND 


d 


MIOHEJS ± '"*"■ 


! 


ADDRESS ± CH *"' 
11 I34I *"* 




0,1 ,0 






6S. 


MOJiMOP' ! ■ , 




, , , . ! ! , . 




n 



Autocoder 



Label Operation 

15 IB 20 21 25 



fiS fl , Ifl fr /ff flQE^. 



OPERAND 
_M 4fi ii 89 



Assembled Instruction: K X55 □ 
Figure 1-63. Reset Overlap and Branch 
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Read Tape (with or Without Word Marks) in 
Overlap Mode 



Instruction Format. 



B-address d-character 
xxx 



Mnemonic Op Code A-address 

SPS MU M @xx xxx R (without 

word 
marks ) 

SPS LU L, @xx xxx R(with 

word 
marks ) 

Note: The move and load operations differ only in the 
handling of the word-separator characters on tape. 

Function. The tape unit specified in the A-address is 
started. The d-character specifies a tape-read opera- 
tion. The @ in the hundreds position of the A-address 
indicates that this operation is to be performed in 
the overlap mode. 

The B-address specifies the high-order position'of 
the tape read-in area of storage. The machine reads 
magnetic tape until either an inter-record gap in the 
tape record or a group-mark with a word-mark in 
core storage is sensed. The inter-record gap indicates 
the end of the tape record, and a group mark ( code 
CBA 8421 ) is inserted in core storage at this point. 

Word Marks. Word marks are not affected in move 
mode. However, a word separator character read 
from tape causes a word mark to be associated with 
the next character transferred to core storage in load 
mode. 



Timing. T = N(Li + l)ms + T M . 
Processing Overlap Timing.) 



(See section on 



Note: 

1. The internal circuitry of the processing-overlap special 
feature temporarily forces the R d-character of the instruction 
into the first position of the specified read-in area. If this first 
position is used to check for a blank field before the first 
character arrives from the I/O unit, the R d-character gives 
a false indication of the read-in area's contents. To ensure 
proper system operation, any blank field checking should use 
some other read-in area position than the first position. 

2. Some of the tape start time is available for processing 
when a tape read operation is being performed in the overlap 
mode. Refer to Figures 1-73 (1401) and 1-77 (1460) for the 
specific times. 

3. Depending on the tape unit, the tape speed, and the 
tape density involved, some of the record transfer time may 
also be available for processing while the tape-read operation 
is being performed in the overlap mode. Refer to Figures 1-74 
(1401) and 1-78 (1460) for the specific times. 

Address Registers After Operation. 



1-Add. Reg. 

NSI 



O-Add. Reg. 
Group mark + 1 



Example. Read the record from the tape unit labeled 2 
to the core-storage area labeled OUTPAR (0419). 



The tape-record characters are moved into core stor- 
age until the transfer is stopped by an inter-record 
gap in the tape record, or a group-mark with a word- 
mark is sensed in core storage (Figure 1-64). 



SPS 



LIKE 


COUNT 


l»!El 


OPERATION 


(») OPERAND 


(•1 OPERAND 




UDNES9 ± CH *" 


j^ 


•00RE9S |±| CH »"- 

» ImI ""■ 


1 


d 


0,1,0 




, . , , , 


MV\ 


$.0.2. ,,::,, 




O.U.T.P.A.Rl I . . 




R 



Autocoder 












Label Operation! 
t is le 20b 


1 25 SO 


35 


40 


OPERAND 

45 50 


T i 


HX . A 


*\i*.O.UTPA8. . 









Assembled Instruction: M @U2 419 R 



Figure 1-64. Read Tape in Overlap Mode (Without Word 
Marks ) 



Write Tape (with or Without Word Marks) in 
Overlap Mode 

Instruction Format. 



Mnemonic 


Op Code 


A-address 


B-address 


d-character 


SPS MU 


M 


@xx 


xxx 


W ( without 
word 
marks 


SPS LU 


L 


@xx 


xxx 


W (with 
word 
marks 



Note: The move and load operations differ only in the 
handling of the word marks in the storage area. 

Function. The tape unit designated in the A-address is 
started. The d-character specifies a tape-write oper- 
ation. The data from core storage is written on the 
tape record. The @ in the hundreds position of the 
A-address indicates that this operation is to be per- 
formed in the overlap mode. 

The B-address specifies the high-order position of 
the record in storage. A group-mark with a word- 
mark in core storage stops the operation. The group- 
mark with a word-mark causes an inter-record gap. 

Word Marks. Word marks are not affected in the move 
mode. However, a word mark associated with any 
position in core storage causes a word-separator 
character (A841) to be written automatically on 
tape, one character ahead of that which contained 
the word mark. Thus, word marks are translated to 
word-separator characters for tape storage. 

Notes: 

1. Some of the tape start time is available for processing 
when a tape-write operation is being performed in the over- 
lap mode. Refer to Figures 1-73 ( 1401), and 1-77 ( 1460) for 
the specific times. 
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2. Depending on the tape unit, the tape speed, and the 
tape density involved, some of the record transfer time may 
also be available for processing while a tape-write operation 
is being performed in the overlap mode. Refer to Figures 
1-74 (1401) and 1-78 (1460) for the specific times. 



Address Registers After Operation. 



1-Add. Reg. 

NSI 



O-Add. Reg. 
Group mark + 1 



Example. Transfer the contents of the core-storage 
area labeled TPOUT (0525) to the tape unit labeled 
3. The transfer of data is stopped by a group-mark 
with a word-mark in core storage ( Figure 1-65 ) . 



SPS 



LINE 


COUNT 


UML 


OPERATION 


It) operand 


(■1 OPERAND 


d 

3» 


AODRESS ± '"*"■ 

IT l»l "'• 


'- 


ADDRESS 1+1 e "*"' 

» l»J ""' 


M 


0,1,0 


, 




mm\ 


KW.3. ..!!.. 




T,P,0,U,T, ! ! , , 




w 



Autocoder 



Label 



Operation 
_!S!S 2S.Z. 



RT.U . &M& t T.f>0VT. 



OPERAND 
_AS 99. 



Assembled Instruction: M @U3 525 W 

Figure 1-65. Write Tape in Overlap Mode (Without Word 

Marks ) 



Read Card in Overlap Mode 

Instruction Format. 

Mnemonic Op Code 

R _1. 

Function. This code, if overlap is on, causes a card to 
feed, and causes all 80 columns of information to be 
read into core-storage locations 001 through 080 
while processing continues. 

Word Marks. Word marks are undisturbed. 

Timing. T = N (L T + 1) ms + I/O. 

Note: Processing is interrupted each time a row in the card is 
scanned (9-row, 8-row, etc.). The bits in a column are 
developed in the A-register, and the O-address register keeps 
track of which column is being scanned. While the scanning 
operation is being performed, the data required for processing 
is temporarily stored in the O-register. When the row scan is 
completed, the data in the O-register is sent back to the 
A-register and processing continues. 

The read-in area of core storage must not be addressed 
while an overlap operation is being performed. 



Address Registers After Operation. 



1-Add. Reg. 

NSI 



O-Add. Reg. 
081 



Example. Read a card in the overlap mode (Figure 
1-66). 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


<»l OPERAND 


(Bl OPERAND 


d 


A00RESS ± eH *"' 


l 


ADDRESS ± CH **' 


: 


0,1,0 


, 


iiii, 


K ! 


■ , , , , ! I , , 




! 1 , , 







Autocoder 


















Lobal 

» 


Operation 

IS IB 20 21 


26 


30 


ss 


AS) 


OPERAND 

49 SO 


i 


ft , , , 






Assembled Instruction: 1 
Figure 1-66. Read Card in Overlap Mode 



Read Card in Overlap Mode and Branch 

Instruction Format. 

Mnemonic Op Code 

R 1 



I-address 
xxx 



Function. This is the same as the read card instruction, 
except that the next instruction is taken from the 
I-address instead of from the next, sequential in- 
struction address. The program branch occurs when 
the instruction is processed; that is, before card read- 
ing is completed. 

Word Marks. Word marks are not affected. 

Timing. 

Without indexing: 

T = N (L x + 1) ms + I/O. 

With indexing: 

T = N (Lx + 2) ms + I/O. 

Address Registers After Operation. 

1-Add. Reg. O-Add. Reg. 

NSI 081 

Example. Read a card in the overlap mode, and branch 
to the location labeled OVERCD (1500), Figure 
1-67. 

SPS 



LINE 


COUNT 


L»«EL 


OPERATION 


Ol OPERAND 


(II OPERAND 


d 


»00»E8S ± ""• 


= 


ADDRESS ± "j^*- 


M 


0,1,0 


, 




ft ! 


nV,E,r?,C,pi ! , , 




II,, 







Autocoder 
















Lobal 

t 15 


Operation 
is 20 


21 25 


30 


35 


40 


OPERAND 
45 so 


1 
1 , , . 


R, . . 


M.tRCD 



Assembled Instruction: 1 V00 

Figure 1-67. Read Card in Overlap Mode and Branch 
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Punch Card in Overlap Mode 

Instruction Format. 

Mnemonic 
P 



Op Code 
4 



Function. This code, if overlap mode is on, causes the 
data in storage locations 101 through 180 to be 
punched into an ibm card while processing con- 
tinues. 

Word Marks. Word marks are not affected. 

Timing. T = N (L x + 1) ms + I/O. 

Note. Processing is interrupted each time a row in the card 
( 12-row, 11 -row, etc.) is scanned for punching. The data to 
be punched is developed in the B-register, and the O-address 
register keeps track of which column is being punched. While 
the punch-scan operation is being performed, the data re- 
quired for processing (from the A-register) is temporarily 
stored in the O-register. When the row punch-scan is com- 
pleted, the data in the O-register is sent back to the A-regis- 
ter, and processing continues. 

The punch-out area of core storage must not be addressed 
while an overlap operation is being performed. 



Address Registers After Operation. 



1-Add. Reg. 
NSI 



O-Add. Reg. 

181 



Example. Feed a card, and punch in overlap mode 
(Figure 1-68). 



SPS 



LIKE 


COUNT 


LABEL 


OPERATION 


(») OPERAND 


1(1 OPERAND 


d 

3t 


ADDRESS ± "*"• 


i 


ADDRESS |±| ""■ 


M 


0,1,0 


, 





P, ! 


II,, 




1 1 , , 







Autocoder 


















Lobel 

• 


■9 


Operation 

IS 20 


21 


26 


SO 


3S 


♦0 


OPERAND 
43 so 


I 
i , , . . I . . . 


R, , , 





Assembled Instruction: 4_ 
Figure 1-68. Punch Card in Overlap Mode 



Punch Card in Overlap Mode and Branch 



Instruction Format. 

Mnemonic Op Code 

P 4 



I-address 
xxx 



Function. This is the same as the punch a card in- 
struction, except that the next instruction is taken 
from die I-address instead of from the next, sequen- 
tial instruction address. The branch occurs when the 



instruction is processed; that is, before punching has 
been completed. 

Word Marks. Word marks are not affected. 

Timing. 
Without indexing: 

T = N (Ln + 1) ms + I/O. 

With indexing: 

T = N (Lx + 2) ms + I/O. 

Address Registers After Operation. 

I-Add. Reg. O-Add. Reg. 

NSI 181 

Example. Punch a card in overlap mode, and branch to 
the location labeled OVSTAT (1758), Figure 1-69. 

SPS 



LINE 


COUNT 


LABEL 


OPERATION 


(A) OPERAND 


(•) OPERAND 


d 


ADDRESS 1 ± I "*"' 


£ 


ADDRESS ± '"*"• 


U 


0,1,0 


, 




P, ! 


QVS7TAT .! , , 




1 , , 







Autocoder 



Label Operation 
S Igfrt ssfc 



P . . . bi/STAT. 



OPERAND 
Si 



Assembled Instruction: 4 X58 
Figure 1-69. Punch Card in Overlap Mode and Branch 

Branch if Indicator On 

Instruction Format. 



Mnemonic 


Op Code 


I-address 


d-character 


SPS B 


B 


xxx 


X 


A BIN 









Function. The d-character specifies the indicator tested. 
If the indicator is on, the next instruction is taken 
from the I-address. If the indicator is off, the next 
sequential instruction is taken. Figure 1-70 shows the 
symbols that are valid d-characters and the indi- 
cators they test. 



d-CHARACTER 


INDICATORS 


H 
1 
J 


Reader Busy 

Punch Busy 

Tape or Input-Output Busy 



Figure 1-70. Processing Overlap Indicators 
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Indicators. Reader Busy. This indicator turns on 
when the ibm 1401 is performing an overlapped read 
operation. The indicator automatically turns off 
when the overlapped read operation is completed. 

Punch Busy. This indicator turns on when the 1401 
is performing an overlapped punch operation. The 
indicator automatically turns off when the over- 
lapped punch operation is completed. 

Tape or Input-Output Busy. This indicator turns 
on when the 1401 is performing an overlapped mag- 
netic tape or input-output (1419, or 1011) operation. 
The indicator automatically turns off when the over- 
lapped operation is completed. 

Word Marks. Word marks are not affected. 

Timing. 

Reader or Punch Busy 
No branch: 

T = N (Li + 1) ms. 

Branch (without indexing): 

T = N (Lx + 1) ms. 

Branch (with indexing): 

T = N (L : + 2) ms. 

Tape or I/O Busy 

No branch (without indexing): 

T = N (Li + 1) ms. 

No branch (with indexing): 

T=N (L r + 2) ms. 

Branch (without indexing): 

T = N (Lj + 1) ms. 

Branch (with indexing): 

T = N (L t + 2) ms. 

Note. When the tape or I/O busy indicator is not on, and in- 
dexing (part of another 1401 or 1460 special feature) is in- 
stalled on the system, an O-Add. Reg.-to-B-Add. Reg. opera- 
tion takes place before going to the next instruction. This 
operation stores the last address used in the normal manner 
for operations such as read-compressed-tape. If indexing is 
not installed, the B-Add. Reg. will contain dbb. 

Address Registers After Operation. 

1-Add. Reg. A-Add. Reg. B-Add. Reg. 



Reader or 
Punch Busy 

No branch NSI 

Branch (without 

indexing ) NSI 

Branch (with 

indexing ) NSI 



BI 



BI 



BI 



dbb 
Blank 

NSI 



Tape or I/O Busy 
No branch ( with- 
out indexing) 


NSI 


BI 


dbb 


No branch ( with 
indexing ) 


NSI 


BI 


O-Add. Reg 
Contents 


Branch (without 
indexing ) 


NSI 


BI 


Blank 


Branch (with 
indexing ) 


NSI 


BI 


NSI 



Example. Test the reader-busy indicator, and branch 
to a routine beginning at the location labeled 
RDBUSY (0891), if the indicator is on (Figure 1-71). 



SPS 



LIRE 


COUNT 


LIBEL 


OPERATION 


(A) OPERAND 


(BI OPERAND 


d 


address |±| "*;• 


I 


ADDRESS ± '""' 


H 


O.I ,0 


, 




a ! 


RP,0,O,5,V! ! , , 




! ! , , 




H 



Autocoder 



Label Operation 

I3ll6 20 21 ifi. 



OPERAND 
-48 82 



e m "to usiyi^^^ 



Assembled Instruction: B 891 H 
Figure 1-71. Branch if Reader Busy Indicator On 



Programming Considerations 

1. A 1-character B-field arithmetic operation, where 
recomplementing can occur, must not be executed 
while an input-output unit is operating in the over- 
lap mode. 

2. During overlap operation the processing-overlap 
internal circuitry initiates a dummy B-cycle at the 
beginning of an overlap execute operation. This B- 
cycle transfers the B-address register contents to 
the O-address register. During this address-register 
transfer operation, the specified core-storage posi- 
tion also reads out to the B-register. This condition 
could cause various problems (see note 1 of the 
read tape in oveblap mode instruction). Another 
example would be during binary tape read opera- 
tion. The first character position could easily con- 
tain a group-mark with a word-mark (sent during 
the last operation). When the group-mark with a 
word-mark is sensed in the B-register during this 
B-cycle, the read-in operation would end, and the 
record would not be transferred. 

3. In general, no other input-output operation can be 
initiated until the preceding overlapped I/O func- 
tion is completed. The exceptions to this rule are: 

a. If the 1401 and/or 1461 is equipped with the 
print-storage special feature, the following print 
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instructions can be executed simultaneously with 
an overlapped input-output function: 

PRINT 

PRINT AND BRANCH 

PRINT WORD MARKS 

PRINT WORD MARKS AND BRANCH 

b. When performing a normal card read instruc- 
tion in the overlap mode, the following output 
instructions can be performed: 

PUNCH 

PUNCH AND BRANCH 

PRINT AND PUNCH 

PRINT, PUNCH AND BRANCH 

PRINT WORD MARKS AND PUNCH 

PRINT WORD MARKS, PUNCH AND BRANCH 

Note: The last four instructions involving the printer 
would require the print storage feature to be installed on the 
system in order for it to be overlapped. 

It is possible to maintain an approximate ratio of three 
card-read operations to one card-punch operation with the 
proper placement of branch on busy instructions. That is, 
after a punch operation, test for punch busy. If it is not 
busy, branch back to punch. If it is busy, test for reader 
busy. If the reader is not busy, perform a read operation and 
branch back to the test-punch-busy operation. If the reader 
was busy, go to the main program (which eventually goes 
to the test-punch-busy operation). 

c. When performing a normal punch instruction, 
the following additional input-output instruc- 
tions can be performed: 

READ 

READ AND BRANCH 

PRINT AND READ 

PRINT, READ AND BRANCH 

PRINT WORD MARKS AND READ 

PRINT WORD MARKS, READ, AND BRANCH 

Note:: The last four instructions would require print stor- 
age in order to be overlapped. 

d. If performing a tape operation in the overlap 
mode, a read or punch instruction in the overlap 
mode can be given successfully so long as the 
total tape operation is completed before the first 
read or punch scan ( inability to store address of 
last position of tape record can result). 

e. The last card indicator is turned on during the 
time the last card is being read. Therefore, to 
ensure proper reading of the card, test for a 
reader busy condition before the branch on last 
card test is given 

The last card indicator is turned off if the sys- 
tem is in an overlap mode, and the program 
completes a successful branch if the last card in- 
dicator is ON. 



System-Interlock Conditions 

The following conditions cause the 1401 system to 
interlock: 

1. When the ibm 1401 and/or 1460 is operating in an 
overlap mode, the system interlocks under certain 
conditions. 

B (xxx) ? branch on reader error. If the reader is 

— operating when this instruction is given, the 
1401 or 1460 interlocks until the overlapped 
operation is completed, before making the 
error test. If punching is being overlapped 
at the same time, the 1401 or 1460 inter- 
locks until the end of the read and the punch 
operations. 

B (xxx) ! branch on punch error. If the punch is 

— operating when this instruction is given, the 
1401 or 1460 interlocks until the overlapped 
operation is completed before making the 
error test. If the reader is being overlapped 
at the same time, the 1401 or 1460 interlocks 
until the end of the read and the punch 
operations. 

B (xxx) L branch on tape transmission error. If 

— the tape adapter unit is busy when this in- 
struction is given, the 1401 or 1460 inter- 
locks until the TAU is not busy, before 
making the test for a tape transmission error. 

B (xxx) H branch on reader busy. If the reader is 

— busy when this instruction is given, and the 
interlock-stop condition is on in the 1402, 
the 1401 or 1460 stops. The stop occurs for 
these conditions: 

a. a card jam in the 1402 read or punch feed 

b. a full stacker 

c. an empty hopper 

d. the I/O check stop switch on the 1401 
or 1460 console is on, and one of the fol- 
lowing conditions occurs: 

Hole-count check 
Validity check 
Punch check 

B (xxx) I branch on punch busy. If the punch is 

~ busy when this instruction is given, and the 

interlock-stop condition is on in the 1402, 

the 1401 or 1460 stops. The stop occurs for 

these conditions: 

a. a card jam in the 1402 read or punch feed 

b. a full stacker 

c. an empty hopper 

d. the I/O check stop switch on the 1401 
or 1460 console is on, and one of the fol- 
lowing conditions occurs: 

Hole-count check 
Validity check 
Punch check 

2. When operating in the overlap mode, the following 
conditions cause a processing unit stop: 

a. When a storage-address error occurs, processing 
stops. 

b. If a process error occurs during an overlapped 
I/O cycle, processing stops immediately; how- 
ever, the input-output operation continues. 
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OPERATION 


1402 CYCLE 


PROCESSING TIME AVAILABLE 


STANDARD 


WITH READ 


WITH PROCESSING 




ms 


ms 


RELEASE ms 


OVERLAP ms 


Read 


75 


10 


31 


63 


Read Column Binary 


75 


10 


31 


52 


Punch 


240 


22 


59 


224 


Punch Column Binary 


240 


22 


59 


212 


Read and Punch 


240 


22 


56 


213 


Read-Punch Feed 


240 


22 


56 


209 



Figure 1-72. Summary of Overlapped Card Operation Timing (1401 system , 



e. If a process error occurs between overlapped I/O 
cycles, processing stops immediately, and the 
input-output operation continues. 

Read and punch-release operation codes (8 and 9 ) 
are not operative in the overlap mode. However, the 
read or punch (1 and 4) operation codes, when used 
in the overlap mode, perform the same function. If 
a tape operation overextends the time allotted it 
( data to or from tape is still being processed when 
data from a card is available), a tape transmis- 
sion error occurs and the data from tape does not 
enter/leave core storage. Normal tape-error proce- 
dure can correct this type of error. If a tape opera- 
tion is given after a read or punch (1 or 4) operation, 
the tape operation and processing are interlocked 
until the read or punch operation is completed. 



Processing-Overlap Timing 

The addition of the processing-overlap special feature 
can provide significant reductions in over-all job times. 
To gain the greatest advantage from this feature, care- 
ful timing consideration should be given to the devel- 
opment of each program and to the operations that 
will be overlapped. Charts showing the increase of 
available processing time by using this feature are in- 
cluded to aid in the efficient placement of the over- 
lapped instructions. 



IBM 1401 System Timing Considerations 

The input-output units that can make use of the proc- 
essing-overlap special feature on the 1401 system are: 

1. ibm 729 Magnetic Tape Units, Models n, iv, v 

2. ibm 1011 Paper Tape Reader, Model 1 

3. ibm 1402 Card Read-Punch, Model 1 

4. ibm 1419 Magnetic Character Reader, Model 1 

5. ibm 7330 Magnetic Tape Unit 



IBM 1011 Paper Tape Reader 

One core-storage cycle is required for the transfer of 
each character read from the 1011. The core-storage 
cycle is 11.5 fisec. The character rate for the 1011 is 
1 character every 2000 /xsec. This leaves an available 
processing time of 1989.5 /xsec between 1011 characters. 

IBM 1419 Magnetic Character Reader 

One core-storage cycle is required for the transfer of 
each character read from the 1419. The core-storage 
cycle is 11.5 /xsec. The actual 1419 speed is dependent 
upon the document length and the stored program. 

IBM 1402 Card Read-Punch 

When reading cards in the overlap mode, processing is 
interrupted each time a row in the card is scanned. 
During a normal 75-ms card read cycle, 63 ms are avail- 
able for other processing. The available processing 
time for this operation, and other card read-punch 
operations, are shown in Figure 1-72. 

Magnetic Tape 

Without the processing-overlap special feature, the 
processing unit is interlocked during the entire tape 
operation. However, the addition of processing overlap 
releases the processing unit so that other processing 
can occur during the tape start times of a high-density 
tape operation as shown in Figure 1-73. 



Tape Unit 


Operation 


Total Start Time (ms) 


Start Time Available 
For Processing (ms) 


7330 


Read 


10.3 


10.3 


Write 


5.0 


5.0 


729 ll/V 


Read 


10.5 


6.6 


Write 


7.5 


7.3 


729 IV 


Read 


6.7 


4.4 


Write 


5.0 


4.9 



Figure 1-73. Magnetic-Tape Start Times Available for 
Processing on 1401 System 
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Tape 
Unit 


Tape 
Density 


Operation 


Tape 

Character 

Rate 

(ms) 


Average 

Transfer 

Per Char 

(ms) 


Average 

Processing Time 

Available 

(ms) 


7330 


200 CPI 


Read 


.139 


.0115 


.127 


Write 


.139 


.0115 


.127 


556 CPI 


Read 


.050 


.014 


.036 


Write 


.050 


.0115 


.038 


729 
ll/V 


200 CPI 


Read 


.067 


.0115 


.055 


Write 


.067 


.0115 


.055 


729 
IV/VI 


200 CPI 


Read 


.044 


.014 


.030 


Write 


.044 


.0115 


.032 



Figure 1-74. Magnetic-Tape Record Transfer Times Available 
for Processing on 1401 System 



Without the processing-overlap special feature, only 
12.8 milliseconds of the total time is available for 
processing. 



IBM 1460 System Timing Considerations 

The input-output units that can make use of the proc- 
essing-overlap special feature on the 1460 system are: 

1. ibm 729 Magnetic Tape Units, Models n, iv, v, vi 

2. ibm 1011 Paper Tape Reader, Model 1 

3. ibm 1402 Card Read-Punch, Model 3 

4. ibm 1419 Magnetic Character Reader, Model 1 

5. ibm 7330 Magnetic Tape Unit 



In addition to making tape operation start times 
available for processing, the processing-overlap special 
feature also makes some time available during the rec- 
ord transfer time at the tape speeds and tape densities 
shown in Figure 1-74. 

Figure 1-75 can be used to help determine the 
amount of processing time available during overlapped 
tape read and/or write operations. 

An example of available processing time is: Reading 
a 1000-character tape record written in high-density 
(556 CPI) on an ibm 7330 Magnetic Tape Unit, with 
the processing-overlap special feature. 



Tape Operation Time 


Total Time Time Available For 




(ms) 


Processing (ms) 


Start Time 


10.3 


10.3 


Record Time 


50.0 


36.0 


Remaining TAU Interlock 






Time 


12.9 


12.9* 


Total Time 


73.2 


59.2 



* Assumes that the tape error indicator is tested at the proper 
time. 



IBM 101 7 Paper Tape Reader 

One core-storage cycle is required for the transfer of 
each character read from the 1011. The core-storage 
cycle is 6 /xsec. The character rate for the 1011 is 1 
character every 2000 /xsec. This leaves an available 
processing time of 1994 yusec between 1011 characters. 



IBM 1419 Magnetic Character Reader 

One core-storage cycle is required for the transfer of 
each character read from the 1419. The core-storage 
cycle is 6 /xsec. The actual 1419 speed is dependent 
upon the document length and the stored program. 



IBM 1402 Card Read-Punch 

When reading cards in the overlap mode, processing is 
interrupted each time a row in the card is scanned. 
During a normal 75-ms card read cycle, 68 ms are 



Tape 
Unit 


Tape 
Density 


Operation 


Tape 

Adapter 

Unit 

Interlocked 

(ms) 


Approximate Processing 
Time Available (ms) 


Approximate 
Gain In 

Processing 
Time (ms) 


Without 
Overlap 


With 
Overlap 


7330 


200 CPI 


Read 


21.1 + CN 


10.5 


21.1+ .127N 


10.6+ .127N 


Write 


20.9+ CN 


15.9 


20.9+ .127N 


5.0+ .127N 


556 CPI 


Read 


20.5 +CN 


10.1 


20.5+ .036N 


10.4+ .036N 


Write 


20.3+ CN 


15.3 


20.3+ .038N 


5.0+ .038N 


729 ll/V 


200 CPI 


Read 


11.1 + CN 


0.6 


11.1+ .055N 


10.5 + .055N 


Write 


12.1 + CN 


4.6 


12.1+ .055N 


7.5 + .055N 


556/800 
CPI 


Read 


10.7+ CN 


0.2 


6.8 


6.6 


Write 


11.7+CN 


4.2 


11.5 


7.3 


729 IV/VI 


200 CPI 


Read 


7.1 + CN 


0.4 


7.1+ .030N 


6.7+ .030N 


Write 


8.1 + CN 


3.1 


8.1+ .032N 


5.0+ .032N 


556 CPI 


Read 


6.8 + CN 


0.1 


4.5 


4.4 


Write 


7.8 +CN 


2.8 


7.7 


4.9 



Figure 1-75. Summary of Available Processing Time During Magnetic Tape Operations on the 1401 System 
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Operation 


1402 

Cycle 

Time (ms) 


Available Processing Time (ms) 


Standard 


With Read 
Release 


With 
Processing 
Overlap 


Read 

Punch 

Read Column Binary 

Punch Column Binary 

Read and Punch 

Punch Feed Read 


75 
240 

75 
240 
240 
240 


10 
22 
10 
22 
22 
22 


31 
59 
31 
59 
56 
56 


68 
230 

63 
224 
224 
223 



Figure 1-76. Summary of Overlapped Card Operation Timing 
(1460 System) 



available for other processing. The available process- 
ing time for this operation, and other card read-punch 
operations, are shown in Figure 1-76. 

Magnetic Tape 

Without the processing-overlap special feature, the 
processing unit is interlocked during the entire tape 
operation. However, the addition of processing overlap 
releases the processing unit so that other processing 
can occur during the tape start times of a high-density 
tape operation as shown in Figure 1-77. 

In addition to making tape operation start times 
available for processing, the process-overlap special 
feature also makes some time available during record 
transfer time on some tape units as shown in Figure 
1-78. 

Figure 1-79 can be used to help determine the 
amount of processing time available during overlapped 
tape read and/or write operations. 



Tape Unit 


Operation 


Total Start Time (ms) 


Start Time Available 
For Processing (ms) 


7330 


Read 


10.3 


10.3 


Write 


5.0 


5.0 


729 II 


Read 


10.5 


10.5 


Write 


7.5 


7.5 


729 IV 


Read 


6.7 


4.4 


Write 


6.0 


4.9 


729 V 


Read 


10.5 


6.6 


Write 


7.5 


7.3 


729 VI 


Read 


6.7 


4.4 


Write 


5.0 


4.9 



Figure 1-77. Magnetic-Tape Start Times Available for 
Processing on the 1460 System 



Tape 
Unit 


Tape 
Density 


Operation 


Character 
Rate 
(ms) 


Average 

Time/Char 

(ms) 


Average 

Processing Time 

Available/Char 

(ms) 


7330 


200 CPI 


Read 


.139 


.006 


.133 


Write 


.139 


.006 


.133 


556 CPI 


Read 


.050 


.006 


.044 


Write 


.050 


.006 


.044 


729 
Il/V 


200 CPJ 


Read 


.067 


.006 


.061 


Write 


.067 


.006 


.061 


556 CPI 


Read 


.024 


.007 


.017 


Write 


.024 


.006 


.018 


729 
IV/VI 


200 CPI 


Read 


.044 


.006 


.038 


Write 


.044 


.006 


.038 



Figure 1-78. Magnetic-Tape Record Transfer Times Available 
for Processing on the 1460 System 



Tape 
Unit 


Tape 
Density 


Operation 


Tape 

Adapter 

Unit 

Interlocked 

(ms) 


Approximate Processing 
Time Available (ms) 


Approximate 
Gain In 
Processing 
Time (ms) 


Without 
Overlay 


With 
Overlay 


7330 


200 CPI 


Read 


21.1 + CN 


10.5 


21.1+ .133N 


10.6+ .133N 


Write 


20.9 +CN 


15.9 


20.9+ .133N 


5.0+ .133N 


556 CPI 


Read 


20.5 +CN 


10.1 


20.5+ .044N 


10.4+ .044N 


Write 


20.3+ CN 


15.3 


20.3+ .044N 


5.0+ .044N 


729 ll/IV 


200 CPI 


Read 


11.1 + CN 


0.6 


11.1+ .061 N 


10.5+ .061N 


Write 


12.1 + CN 


4.6 


12.1+ .061N 


7.5+ .061N 


556 CPI 


Read 


10.7+ CN 


0.2 


10.7+ .017N 


10.5+ .017N 


Write 


11.7+ CN 


4.2 


11.7+ .018N 


7.5+ .018N 


729 V 


800 CPI 


Read 


10.7+ CN 


0.2 


6.8 


6.6 


Write 


11.7+ CN 


4.2 


11,5 


7.3 


729 IV/VI 


200 CPI 


Read 


7.1 + CN 


0.4 


7.1+ .038N 


6.7+ .038N 


Write 


8.1 + CN 


3.1 


8.1+ .038N 


5.0+ .038N 


556 CPI 


Read 


6.8 +CN 


0.1 


4.5 


4.4 


Write 


7.8+ CN 


2.8 


7.7 


4.9 


729 VI 


800 CPI 


Read 


6.8+ CN 


0.1 


4.5 


4.4 


Write 


7.8 +CN 


2.8 


7.7 


4.9 



Figure 1-79. Summary of Available Processing Time During Magnetic Tape Operations on the 1460 System 
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Some examples of available processing time are: 

1. Reading a 1,000-character tape record written in 
high density on an ibm 729 n tape unit, with the 
processing-overlap special feature. 



Tape Operation Time 


Total Time 

(ms) 


Time Available 
for Processing (ms) 


Start Time 
Record Time 

Remaining TAU Interlock 
Time 


10.5 
24.0 

.2 


10.5 
17.0 

.2* 


Total Time 


347 


27.7 



* Assumes that the tape error indicator is tested at the proper 
time. 

2. Writing a 1,000-character tape record in high 
density on an ibm 7330 tape unit, with the process- 
ing-overlap special feature. 



Tape Operation Time 

Start Time 
Record Time 

Remaining TAU Interlock 
Time 

Total Time 



Total Time Time Available 
(ms) for Processing (ms) 

5.0 5.0 

50.0 44.0 



15.3 
703 



15.3 * 
64.3 



* Assumes that the tape error indicator is tested at the proper 
time. 

3. Writing a 1,000-character tape record in high 
density ( 800 CPI ) on an ibm 729 vi tape unit, with 
the processing-overlap special feature. 



Tape Operation Time 


Total Time 


Time Available 




(ms) 


for Processing (ms) 


Start Time 


5.0 


4.9 


Record Time 


11.1 


_ 


Remaining TAU Interlock 






Time 


2.8 


2.8* 


Total Time 


18.9 


7.7 



* Assumes that the tape error indicator is tested at the proper 
time. 



Punch-Feed Read Control (1401, 1460) 

This feature is required when the punch-feed-read 
special feature is installed on the ibm 1402 Card Read- 
Punch, Model 1 or Model 3. The feature provides the 
controlling circuitry necessary for the proper operation 
of the punch-feed-read special feature. For detailed 
information on the feature, refer to the ibm 1402 Card 
Read-Punch, A24-3072. 



Read-Compare Adapter (1401) 

This feature provides the controlling circuitry for the 
read-compare feature on the ibm 1404 Printer. For de- 
tailed information, refer to the ibm 1404 Printer, A24- 
1446. 



Read-Punch Release (1401, 1460) 

With this feature, it is possible to release the read-start- 
time and punch-start-time interlocks that normally 
occur during card-read and card-punch cycles, thus 
providing more processing time during input-output 
operations. 

Start Read Feed 



Instruction Format. 

Mnemonic 
SRF 



Op Code 



Function. This instruction works in conjunction with 
the read-release special feature. It releases the inter- 
lock that occurs during read start time,, and permits 
a gain of 21 milliseconds of processing time between 
card-read cycles. Also, it activates the card-read feed 
and moves the next card into reading position. 

Word Marks. Word marks are not affected. 



Timing. T = N (L r + 1) ms. 

Note. After the start read feed instruction is executed, a 
read a card instruction must be given before the reader is 
ready to read the 9-row of the card. If the read card 
instruction comes too late, then the card is not read, and 
feeds into the nr pocket, and the machine stops. The reader 
light comes on, and the I-address register is at the location 
of the instruction following the one on which read release 
time was overextended. To ensure optimum processing time, 
a start feed read instruction should follow the read card 
instruction, within 10 ms, if continuous card reading is 
desired. Then the machine is ready to accept the next read 
instruction on the following cycle. 

start read feed instructions can also be given in cases 
other than those that cause continuous card feeding, provided 
that a read a card instruction follows within the next 21 
milliseconds. For this reason subroutines that can be executed 
after the start read feed instruction has been given should 
be timed to determine whether a read card instruction is 
necessary in the subroutine as well as in the main routine. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
Ap 



R-Add. Reg. 
Bp 
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Example. Release the interlock on the card reader and 
feed a card (Figure 1-80). 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


(») OPERAND 


(1) OPERAND 


d 


ADDRESS ± C "*"' 


J, 


2. I M I *"' 


= 


0,1,0 


, 




&KIP 


| ] , , 




ii,, 







Autocoder 


















Label 
e is 


Operation 

16 20 


21 


26 


30 


35 


40 


OPERAND 

45 50 


s ! 


3.Rf. . 





Assembled Instruction: 8 



Figure 1-80. Start Read Feed 



Note. After a start punch feed instruction is executed, a 
punch a card instruction must follow before the machine is 
ready to punch the 12-row of the card. If no punch card 
instruction is interpreted, the card feeds past the punch 
station without being punched and the machine stops. (The 
card punched on the previous cycle is not checked.) The 
I-address register is at the location of the instruction fol- 
lowing the one on which punch release time was overex- 
tended. For this reason, if cards are to be punched every 
cycle, a start punch feed instruction should be given within 
22 ms after the punch card instruction, so that the machine 
is ready to punch the next card on the following punch 
cycle. If cards are not to be punched every cycle, a punch 
card instruction should always follow a start punch feed 
instruction within 37 ms to ensure proper machine operation. 
When the punch-release special feature (Op code 9) is 
used in conjunction with punch-read-feed special feature 
( Op code 4R ) , the .9 Op code must have an R d-modifier. 
The R d-modifier activates the punch-feed-read brushes. 



Start Punch Feed 

Instruction Format. 

Mnemonic 
SPF 



Op Code 
9 



Function. This instruction works in conjunction with 
the punch-release special feature. It releases the 
interlock that occurs during punch start time, and 
allows a gain of 37 milliseconds of processing time 
between card punch cycles. It also activates the card 
feed, and moves the card into punching position. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms. 



Address Registers After Operation. 



I- Add. Reg. 

NSI 



A-Add. Reg. 
Ap 



B-Add. Reg. 
Bp 



Example. Release the punch interlock, and feed a card 
(Figure 1-81). 



SPS 



LINE 


COUNT 


LABEL 


OPERATION 


(Al OPERAND 


(•1 OPERAND 


d 


ADDRESS |±| ""■ 


J 


ADDRESS ± C "*"- 
j [ ADJ. 


^ 


0,1,0 


, 




Wlf 






Ill, 







Autocoder 


















Lobel 

■ 15 


Operation 
16 20 


21 


26 


30 


35 


40 


OPERAND 

45 50 


s ! 

■ • ■ 


Mf*. . 





Assembled Instruction: 9 
Figure 1-81. Start Punch Feed 
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Scan Disk (1460) 



The scan-disk special feature provides an automatic 
search of 1311 and/or 1301 (Models 11, 12, 21, 22) disk 
data for a specific identifier or conditions predeter- 
mined by the program. 



Scan Disk 



Instruction Format. 



Mnemonic 

SPS MU 

LU 



Op Code 
M or L 



A-address 

7 



B-address 



d-character 
W 



A SDL ( core contents = disk-record contents ) 
SDE ( core contents = disk-record contents ) 
SDH ( core contents = disk-record contents ) 
SDLW ( core contents = disk-record contents — 

word marks ) 
SDEW ( core contents = disk-record contents — 
word marks ) 

SDHW ( core contents = disk-record contents — 
word marks ) 

Function. This instruction compares a specified search 
argument in core storage (factor B) to the records 
within a specified group of sectors in disk storage 
( factor A ) . 

The A-address units position controls the opera- 
tion. A 7 in the units position specifies a scan opera- 
tion that stops when the search argument in core 
storage is either less than (B < A), or equal to 
(B = A), a record in the specified section of disk stor- 
age. An 8 specifies a scan operation that stops when 
the search argument in core storage is equal to 
( B = A ) , a record in the specified section of disk 
storage. A 9 specifies a scan operation that stops 
when the search argument in core storage is either 
higher than ( B > A ) , or equal to ( B = A ) , a record 
in the specified section of disk storage. (The opera- 
tion also stops when the end of the cylinder is 
reached, or when the sector count reaches zero. ) 

The B-address of the instruction specifies the 
high-order core-storage position of the disk-control 
field that specifies the starting address in disk stor- 
age. The record area associated with the disk-control 







Starting Address Control Field 


Core Storage 


*01231020$$$A45798* 


B-address 


J 


Search Argument 



Figure 1-82. Record in Core Storage for Scan Operation 

field contains the search argument. The search argu- 
ment must be placed in the same positions of the 
core-storage record as it appears in the disk-storage 
record. Skip codes ($) are used in those positions of 
the core storage read-in that are not a part of the 
search argument (Figure 1-82). The search argu- 
ment can be variable in length, but must be no 
longer than 99 characters. The last character of a 
sector (100th) cannot be included as part of the 
search argument. The units positions of the search 
argument should be followed by a group-mark with 
a word-mark that signals the end of the search argu- 
ment. 

Scanning begins at the disk record specified by 
the B-address and ends 

1. when the specified comparison is found. The 
sector-count field may, or may not, be all zeros at 
this time. 

2. when the operation reaches the end of a cylinder. 
The sector-count field may, or may not, be all zeros 
at this time. 

3. when the sector-count field is reduced to all zeros. 

Word Marks. A group-mark with a word-mark must be 
set one position to the right of the last character of 
the search argument. 

Timing. T = .006 (L r + 1) + 2N S + disk rotation. 400 
ms is the maximum time for scanning one 1311 cylin- 
der ( 200 sectors ) ; 1,332 ms is the maximum time for 
scanning one 1301 cylinder (800 sectors). 

Note. The result of the scan is determined by testing the high, 
low, or equal compare indicators with the branch if indi- 
cator on instruction. 

The scan operation can be performed only on disk records 
written in sector format. 



Address Registers After Operation. 



1-Add. Reg. 

NSI 



A-Add. Reg. 
B + 6 



B-Add. Reg. 
B + 11 + Lf 



Example. Scan disk storage for an equal compare be- 
ginning at sector-address 012510 and continue scan- 
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ning until the record with part number A24537 is 
found. The disk-control field is located in the high- 
order positions of the area of core storage labeled 
SCANAR (966-974), Figure 1-83. 



SPS 



LIKE 


COUNT 


LABEL 


OPERATION 


IAI OPERAND 


(81 OPERAND 


d 


AOORESS i C 4 H " 


1 


„ """"'* IfJ «'"' 


i 


0,1,0 




, , , , , 


mu: 


b=,8, ,,!!,, 




S.CANAR; ! ,_, 




w 



Autocoder 



Label Operatic 



. IS.DE, , BCANAR 



OPERAND 
—31 Sfl 



Assembled Instruction: M %F8 966 W 
Figure 1-83. Scan Disk Equal 



Seek-Over lap Adapter (1460) 

This feature is required when the seek-overlap feature 
is installed on the ibm 1311 Disk Storage Drives at- 
tached to a 1460 system. This feature provides some of 
the circuitry necessary for proper operation of the 
seek-overlap feature. 



Selective-Tape-Listing Control (1401, 1460) 

This feature is required when the selective-tape-list- 
ing special feature is installed on the ibm 1403 Printer, 
Model 1, 2, or 3, and it provides the controlling cir- 
cuitry necessary for proper operation of the selective- 
tape-listing feature. 



Sense Switches (1401) 

Six sense switches make it possible to control the stored 
program from the 1401 console (Figure 1-84). The 
branch if indicator on instruction expands to allow 
the program to test each switch. 



ft B w u c r vj 

a §» m a a m a 



Figure 1-84. Sense Switches 
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For example, a sense switch is turned on if printing 
only is required for a given job. If the switch is off, 
the data is to be printed and punched. 

The program can be written to interrogate the set- 
ting of this sense switch, to determine whether the 
data is to be printed and punched or just printed. The 
setting of a sense switch should not be changed while 
the system is operating. 



Branch if Indicator On 

Instruction Format. 

Mnemonic Op Code 

SPS B B 

A BIN + d-character 



I-address 



d-character 



Function. This instruction tests the position of the tog- 
gle switch specified by the d-character. If the switch 
is in the on position, the next instruction is taken 
from the I-address. If it is off, the program con- 
tinues with the next sequential instruction. 



d-character 
B 
C 
D 
E 
F 
G 



Branch to the I-address if: 
Sense switch B is on 
Sense switch C is on 
Sense switch D is on 
Sense switch E is on 
Sense switch F is on 
Sense switch G is on 



Word Marks. Word marks are not affected. 

Timing. 
No branch: 

T = N (Li + 1) ms. 

Branch (without indexing): 

T = N (L r + 1) ms. 

Branch (with indexing): 

T = N (Lx + 2) ms. 

Note. Sense switch A (last card switch) is standard in all sys- 
tems equipped with an ibm 1402 Card Read-Punch. When 
the last card passes the second reading brushes, and switch 
A is in the on position, the last-card indicator is turned on 
and a B xxx A instruction causes a branch to the I-address. 
It is turned off; on a run-in; if the switch is physically 
turned off; or if the start reset key is pressed. 

Address Registers After Operation. 





I-Add. Reg. 


A-Add. Reg. 


B-Add. Reg. 


No Branch 


NSI 


BI 


Abb 


Branch (without 








indexing ) 


NSI 


BI 


Blank 


Branch (with 








indexing ) 


NSI 


BI 


NSI 



Example. Branch to the subroutine labeled CLWARE 
(beginning at 0585) if sense switch G is on (Figure 

1-85). 
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Assembled Instruction: B 585, G 



Figure 1-85. Branch if Indicator (Sense Switch G) On 



This special feature makes it possible to have 729 n, 
iv, v, vi and 7330 magnetic tape units in any combina- 
tion, connected to the same 1401 and/or 1460 system 
at one time. Thus, the tape units best suited for the 
job to be done can be used. Some jobs may require a 
pair of high-speed tape units ( 729 iv's ) while the re- 
mainder of the operation can be performed on a slower 
unit (7330). 

Now, any combination of tape units can be provided 
to best suit the need of the application, thereby greatly 
increasing the flexibility of the ibm 1401 and 1460 Data 
Processing Systems to meet the requirements of any 
application. 



Serial Input/Output Adapter (1401, 1460) 

This special feature is required to attach these compo- 
nents to the 1401 and 1460 systems: 

1009 Data Transmission Unit 

1011 Paper Tape Reader 

1012 Tape Punch 

1412/1419 Magnetic Character Reader 

1418 Optical Character Reader 

1428 Alphameric Optical Reader 

7710 Data Communication Unit (1401 only) 

Direct Data Channel 

7040/7044 System (1401 only) 

One adapter can be used for any of these attachments, 
but only one attachment can be connected at a time. 



Track Record (1460) 

The track-record special feature provides for reading 
or writing an entire disk track with or without the 
track address. For ibm 1311, a single, 6-digit address 
is used, followed by 2,980 characters (2,543 for ibm 
1301) in the move mode and 2,682 characters (2,261 
for ibm 1301 ) in the load mode. Track records can be 
used for storing programs, tables, blocked records, and 
other data requiring a single large storage block. 

When this feature is installed on the system, it pro- 
vides the track-record function to all the attached 
1301 and 1311 drives. 



Space Suppression (1401; 
Standard on 1460) 

This feature provides program control for space sup- 
pression on the printer attached to the system. The 
character S is used as a d-modifier character with any 
write instruction (operation codes 2, 3, 6, 7). The S 
prevents the automatic spacing operation after the 
next print operation. The next line printed appears on 
the same line as the line printed by the space suppress 
instruction— 2 S. 



B-address d-character 
xxx R 



Read Disk-Track Record 

Instruction Format. 

Mnemonic Op Code A-address 
SPS MU MorL %F2 

LU ( word marks ) 
A RDTR 

RDTRW (word marks) 



Function. This instruction causes data to be read from 
a disk track into core storage. The digit 2 in the 
A-address ( %F2 ) specifies that a track-record opera- 
tion is to be performed. From the 1311 disk track 
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2,980 characters (2,543 for 1301) are read in move 
mode or 2,682 characters (2,261 for 1301) in load 
mode. The additional characters read are accounted 
for by using the normal gap between disk sectors 
and the sector-address positions. Reading from the 
disk is stopped by a group-mark with a word-mark 
in core storage. 

Reading from the track begins following the ad- 
dress specified by the core-sector address. This ad- 
dress is located at the beginning of the track, directly 
after the index pulse. 

The core-sector address field in core storage is not 
modified, but the sector-count field in core storage is 
reduced by one as the track is read. The sector-count 
field must be set at 001 before the operation begins, 
so that reducing it by one can signal an end-of- 
operation (000 in sector-count field). 

The B-address specifies the high-order position in 
core storage of the disk-control field, and the area in 
storage reserved for data read from the disk track. 

The R in the d-character position signifies that 
this is a read operation. 

Word Marks. A group-mark with a word-mark must be 
one position to the right of the last position reserved 
in core storage for the track record. If a group-mark 
with a word-mark is detected before reading of the 
track is completed, the wrong-length record and 
any-disk condition indicators turn on and reading 
stops. For the 1311, the position of the group-mark 
with a word-mark is determined by adding 2,991 
(2,554 for ibm 1301) to the B-address. 

1311 Timing. T = .006 (Li + 1) + 40 ms + disk rota- 
tion.* 

*42 ms is maximum time for disk rotation. 
22 ms is average time for disk rotation. 
2 ms is minimum time for disk rotation. 

1301 Timing. T = .006 (Li + 1) + 33.3 ms + disk rota- 
tation.* 

*35 ms is maximum time for disk rotation. 
18.3 ms is average time for disk rotation. 
1.7 ms is minimum time for disk rotation. 

Note. Track-record read operations can be performed only on 
a track written with a track record instruction. 

Before reading starts, an automatic check is made of the 
record address in storage with the record address on the disk. 
If the addresses are not the same, the unequal-address com- 
pare and any-disk condition indicators are turned on, and the 
data in storage cannot be read from the disk. 

Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
B + 6 



(1311) 

B-Add. Reg. 

B + 11 +2980 



(1301) 

B-Add. Reg. 

B + 11 +2543 



Example. Read disk track 012540 in core storage begin- 
ning at location 976 (area is labeled TRSEC1). The 
high-order position of the disk address is in the first 
ten positions of the label (966-975), Figure 1-86. 
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Assembled Instruction: M %F2 966 R 
Figure 1-86. Read Disk Track Record 



Read Disk-Track Record with Address 

This instruction is the same as read disk-track record 
with these exceptions: 

Instruction Format. 

Mnemonic Op Code A-address B-address d-character 
SPS MU MorL %F@ xxx R 

LU ( word marks ) 
A RDTA 

RDTAW (word marks) 

Function. The @ in the A-address (%F@) specifies 
that the address of the track record in disk storage 
is also read into core storage with the data on the 
disk track. 

When a disk-track record operation is initiated, an 
automatic check is made of the record address in 
storage with the record address on the disk. If the 
addresses are equal, reading begins immediately fol- 
lowing the index pulse on the disk track. ( The index 
pulse signals the system that the beginning of a 
track is about to come under the access assembly.) 
The track-record address in the high-order position 
of the disk data field in core storage is written in the 
first sector -address position after the index pulse. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
B + 9 



(1311) 

B-Add. Reg. 

B + 11 +2986 

or 
B + 11 +2988 



(1301) 

B-Add. Reg. 

B + 11 +2549 

or 

B + 11 + 2267 



or or 

B + 11 +2682 B + 11 + 2261 



Example. Read the address and data from disk track 
012540 into core storage beginning at location 476 
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(area is labeled TREC'AD). The high-order position 
of the disk-control field is in the first ten positions of 
the label (466-475), Figure 1-87. 
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Figure 1-87. Read Disk Track Record with Address 



Write Disk-Track Record 



Instruction Format. 



A-address 

%F2 



B-address 



d-character 
W 



Mnemonic Op Code 
SPS MU MorL 

LU ( word marks ) 
A WDTR 

WDTRW (word marks) 



Function. This instruction causes data from core stor- 
age to be written on a disk track. The digit 2 in the 
A-address (%F2) specifies that a track-record opera- 
tion is to be performed. From core storage an entire 
1311 disk track of 2,980 characters (2,543 for 1301) is 
written in move mode or 2,682 characters (2,261 for 
1301) in load mode. The additional characters are 
accounted for by writing in what is normally the 
gap between disk sectors and the sector address 
positions. Writing of a disk track is stopped by 
sensing a group-mark with a word-mark in core 
storage and the end of track. 

Writing begins at the track address specified by 
the core-sector address field. This address is located 
at the beginning of the track, directly after the index 
pulse. 

The core-sector address field in storage is not mod- 
ified, but the sector-count field in core storage is re- 
duced by one as the track is written. Set the sector- 
count field to 001 before the operation begins so that 
reducing it by one can signal an end-of-operation 
(000 in sector-count field). 

The B-address specifies the high-order position in 
core storage of the disk-control field, and the area in 
storage where the data to be written on the disk 
track is stored. 



The W in the d-character position signifies that 
this is a write operation. 

Word Marks. A group-mark with a word-mark must be 
one position to the right of the last character of the 
data in core storage. The writing of data stops when 
the end of track is reached on the disk and a group- 
mark with a word-mark is sensed in core storage. If 
the group-mark with a word-mark is sensed before 
the end of track, the remainder of the disk track is 
filled with data from core storage, and the wrong 
length record and any-disk condition indicators are 
turned on. For the 1311, position of the group-mark 
with a word-mark is determined by adding 2,991 
(2,554 for 1301) to the B-address. 

1311 Timing. T = .006 (Li + 1) + 40 ms + disk rota- 
tion.* 

*42 ms is maximum time for disk rotation. 
22 ms is average time for disk rotation. 
2 ms is minimum time for disk rotation. 

1301 Timing. T = .006 (L T + 1) + 33.3 ms + disk ro- 
tation.* 

*35 ms is maximum time for disk rotation. 
18.3 ms is average time for disk rotation. 
1.7 ms is minimum time for disk rotation. 

Note. Before writing starts, an automatic check is made of the 
core-sector address in storage with the record address on 
the disk. If the addresses are not the same, the unequal- 
address compare and any-disk condition indicators are turned 
on, and the data in storage cannot be written on the disk. 

A write disk check instruction must be performed fol- 
lowing a write operation unless an error occurred during the 
write operation. No other disk-storage operation can be per- 
formed until the check of data written on the disk is ac- 
complished. 

If the data in core storage contains characters with word 
marks and the write operation is performed in the move 
mode, only the CBA 8421 portion of the character is written 
on the disk (the word mark is ignored). 

Disk tracks adjacent to, but not above or below, a disk 
track written with the write disk-track record instruction 
must be either unused or set up as a track record. If the 
adjacent tracks are written using write disk sector or write 
disk sector with addresses instructions, interference occurs 
to the track-record data stored in what is normally the gap 
between sectors. 

Address Registers After Operation. 

(1311) (1301) 

I-Add. Reg. A-Add. Reg. B-Add. Reg. B-Add. Reg. 

NSI B + 6 B + 11 +2980 B + 11 +2543 

or or 

B + 11 +2682 B + 11 +2261 

Example. Write a disk-track record from the data in 
the core-storage area labeled TRSEC1 (the first posi- 
tion of data is at 976). The high-order position of the 
disk address is in the first ten positions of the label 
(966-975), Figure 1-88. 
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Assembled Instruction: M %F2 966 W 



Figure 1-88. Write Disk Track Record 



Write Disk-Track Record with Address 

This instruction is the same as write disk-track rec- 
ord with these exceptions : 

Instruction Format. 

Mnemonic Op Code A-address B-address d-character 
SPS MU MorL %F@ xxx W 

LU ( word marks ) 
A WDTA 

WDTAW (word marks) 

Function. The @ in the A-address (%F@) specifies 
that the address of the track record in core storage 
is also written on the disk. 

When a disk track-record operation is initiated, an 
automatic check is made of the record address in 
storage with the record address on the disk. If the 
addresses are equal, writing begins immediately fol- 
lowing the index pulse on the disk track. (The index 
pulse signals the system that the beginning of a 
track is about to come under the access assembly.) 
The track-record address in the high-order position 
of the disk data field in core storage is written in the 
first sector-address position after the index pulse. 

Word Marks. A group-mark with a word-mark must be 
one position to the right of the last character of data 
in core storage. The writing of data stops when the 
end of track is reached on the disk and a group-mark 
with a word-mark is sensed in core storage. If the 
group-mark with a word-mark is sensed before the 
end-of-track, the remainder of the disk track is 



filled with valid blanks (C-bit), and the wrong-length 
record, and any-disk condition indicators are turned 
on. Processing is interlocked until the end of the 
sector. For the 1311, the position of the group-mark 
with a word-mark is determined by adding 2,997 
(2,560 for 1301) to the B-address. 

Note. Before writing starts, an automatic check is made of the 
core-sector address in storage with one of the sector addresses 
on the pack. If the address is not found the unequal-address 
compare and any-disk condition indicators are turned on, and 
the data in storage cannot be written on the disk. 

A write disk check instruction must be performed fol- 
lowing a write operation. No other disk-storage operation can 
be performed until the check of data written on the disk is 
accomplished. 

If the data in core storage contains characters with word 
marks and the write operation is performed in the move mode, 
only the CBA 8421 portion of the character is written on 
the disk (the word mark is ignored). 

Disk tracks adjacent to, but not above or below, a disk 
track written with the write disk track record or write 
disk track record with address instructions must be either 
unused or set up as a track record. If the adjacent tracks are 
written using write disk sector or write disk sector with 
addresses instructions, interference occurs to the track-record 
data stored in what is normally the gap between sectors. 

The write-address key on disk-storage-drive zero must be 
on to perform this operation. 



Address Registers After Operation. 



1-Add. Reg. 

NSI 



A- Add. Reg. 
B + 9 



(1311) 

B-Add. Reg. 

B + 11 + 2986 

or 
B + 11 + 2688 



(1301) 

B-Add. Reg. 

B + 11 + 2549 

or 
B + 11 + 2267 



Example. Write a disk-track record with its new ad- 
dress from the data in the core-storage area labeled 
TRECAD (the first position of the address is at 476). 
The high-order position of the disk-control field is in 
the first ten positions of the label (466-475), Fig- 
ure 1-89. 
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Assembled Instruction: M %F@ 466 W 
Figure 1-89. Write Disk Track Record with Address 
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Translate (1460) 



This special feature provides the data processing sys- 
tem with the capability of fast, flexible translation of 
codes to and from the code of the system. 

The feature uses stored-program instructions to in- 
itiate the code translation and subsequent record 
movement. (IOCS for this feature is described in the 
SRL publication IOCS for the 1440/1448: Specifica- 
tions, Form C24-3024. ) One translate instruction trans- 
lates a complete record, moving left to right as it re- 
places each record character with a character from a 
translate table in core storage until a group-mark with 
a word-mark is detected in the field being translated. 

Each code translation requires a table in storage 
beginning at an even-hundreds address for translate- 
with-word-marks and at any hundreds address for 
translate- without- word-marks. The number of vari- 
ous code translations that can be handled at one time 
in a system is limited only by the core storage avail- 
able for tables. 

The load record instruction (included in the trans- 
late feature) moves characters and word marks from 



an A-field to a B-field, moving left to right up to and 
including an A-field group-mark with a word-mark. 
Original B-field word marks are cleared. 



Translate with Word Marks 



Op Code 
T 



A-address 
xxx 



B-address 
xOO 



d-character 
> 



The translate-with-word-marks instruction con- 
sists of T ( C-A-2-1-WM ) for the operation code, a 3- 
character A-address representing the initial address 
of the record to be translated, a 3-character B-address 
representing the initial address of the translate table, 
and a d-character with a bit configuration of 8-4-2. 

The record to be translated must end with a group- 
mark with a word-mark. The initial address of the 
translate table is restricted to any available even- 
hundreds address such as 200, 400, 600, 800, or 1000. 
Two table sizes can be accommodated: a 78-character 
table provides as many as 64 usable positions, and a 
156-character table provides as many as 128 usable po- 
sitions. (Figures 1-90 and 1-91 show that the digits 8 
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(Note: X in table address represents any hundreds-position digit.) 



Figure 1-90. Baudot Code to Translate-Table Address 
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and 9 are not used in the units or hundreds position of 
any generated address of the translate table.) The 
156-character table consists of the 78-character table, 
beginning at an even-hundreds address (for example 
200-277), combined with another 78-character table, 
beginning at the next sequential hundreds address 
(300-377). 

Characters and word marks from the translate table 
(initial address specified by B-address) replace the 
characters and word marks in the record being trans- 
lated, beginning at the address specified by the A- 
address of the translate instruction. 

The translate-with-word-marks instruction inter- 
prets word marks in the A-address field as data or 
shift bits, and the word marks actually take part in 
the translate function. 

The translate instructions are interruptible. 

The B-field address (initial translate-table address) 
cannot be indexed. 



Translate Without Word Marks 



Op Code 
T 



A-address 
xxx 



B-address 
xOO 



The translate-without-word-marks instruction 
format is the same as the translate-with-word-marks 
instruction, but without a d-character. It functions the 
same, with these exceptions: 

1. One table size can be accommodated: the 78-char- 
acter table, which provides as many as 64 usable 
positions. 

2. A-field word marks do not take part in the actual 
translation, and are not altered by the translation. 



General Description of Translate 

The program assigns locations and contents in the 
translate tables depending on the desired translation. 
Each position of the translate table contains the BCD 
character to which a particular character is to be trans- 
lated. For each character to be translated, the translate 
feature automatically selects the appropriate position 
of the translate table. The contents of that position 
replaces the character in the A-field. The contents of 
the translate table are undisturbed. 

The translate-table characters must contain odd 
parity. The input/output device, channel or adapter 
(for example, the ibm 1448 Transmission Control Unit) 
performs any necessary parity conversion for input and 
output. The tables also must contain required shift 
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Note: Word marks with the BCD characters will generate the same 
sequence of addresses at (X+1)00, (X+l)01, etc. 



Figure 1-91. 



BCD Character Generates Translate-Table 
Address 



bits or shifted codes. The adapter detects SHiFT-bit 
transitions, generates the required shift character, and 
removes the shift bit. 

Figure 1-90 is an example of how a code (Baudot 
telegraph code in this case) enters the system and the 
addresses that are generated ( assuming Baudot 1-2-3- 
4-5 bits respectively, are equal to BCD bits B-A-8-4-2 
with the 1-bit designating figures shift). 

Figure 1-91 shows the BCD character and the table 
address generated. 

Translation of each character is accomplished in a 
3-cycle sequence (first A-cycle, B-cycle, and second 
A-cycle). Refer to Figure 1-92 while reading the se- 
quence described here. Here again Baudot code is 
used as an example. 

Although the examples show the function of the 
translate with incoming data, it functions the same 
way for outgoing data using another translate table. 

First A-Cyele 

The first A-cycle generates the appropriate translate- 
table address specified by the character to be trans- 
lated. 
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900 901 902 903 



B-REG . 





A-field 

(Record to be translated) 



1 





2 


1 


4 


1 


8 





A 


1 


B 





C 





WM 






1 . Transfer to units position of storage address register as 1-2-4. 

2. Generate parity. 

3. if all zeros, generate 8-2-C to storage address register 
units position. 



1 . Transfer to tens position of storage address register as 1-2-4. 

2. Generate parity. 

3. If all zeros, generate 8-2-C to main address register units 
position . 



If the instruction is translate-with-word-marks, WM is trans- 
ferred as a 1-bit combined with even bits of B-address register 
to storage address register. 



,i /i 



H 



Storage Address Register at beginning of cycle. 
Storage Address Register at end of cycle. 







6 


Blank 


Blank 



A-Address Register 

(Remains the same before 
and at the end of first 
A-cycle) 



B-Address Register 

(Initial Table Address) 



(Translate Instruction) T 900 600 > 
Figure 1-92. First A-cycle of Translate Sequence 



The translate instruction acts upon all the characters 
of the A-field. Figure 1-92 shows how the instruction 
T 900 600 (as an example) translates one character. In 
this case the first character of the A-field is used as the 
example. The contents of position 900 has a bit con- 
figuration of 2-4- A ( Baudot-code G ) . 

The first A-cycle moves this first character in the 
A-field to the B-register. From the B-register, the 
operation moves the 1-2-4 bits of this character (with 
proper parity) to the units position of the storage- 
address register together with the A-B bits from the 
units position of the B-address register. A-B bits in the 
units position of the generated address designate core- 
storage blocks over 3999. In Figure 1-92 the 2-4 bits 
produce a 6 in the units position of the storage-address 
register. If the 1-2-4- bits are all blanks ( no-bits ) , the 
operation generates an 8-2-C bit configuration (zero) 
into the units position of the storage-address register. 

The first A-cycle also moves the 8-A-B bits (inter- 
preted as 1-2-4 bits) of the same character (with 
proper parity) to the tens position of the storage- 
address register. In Figure 1-92 the A-bit, which be- 
comes a 2-bit, produces a 2 in the tens position of the 
storage-address register. Again, if the 8-A-B bits are 
all blanks, the operation generates an 8-2-C bit con- 
figuration ( zero ) into the tens position of the storage- 
address register. 

If the instruction is a translate-with-word-marks, 
a word-mark bit in the B-register is interpreted as a 1- 
bit and is combined with the bits already selected for 



transfer to the hundreds position of the storage- 
address register. This adds 1 to the hundreds position 
of the storage-address register and thus generates an 
address from the second half of a 156-character table. 
If the table's base address was 600 (as in Figure 1-92) 
the generated address would be 726. Because in the 
example the B-register has no word mark, the gener- 
ated address is 626. 

A TRANSLATE-WITHOUT-WORD-MARKS instruction 

blocks a word mark in the B-register so it takes no part 
in the generation of the address. 

B-Cycle 

The B-cycle of the operation reads a character or char- 
acter with word mark out of a specified translate-table 
address in storage into the A-register. It uses the ad- 
dress generated in the first A-cycle. The translate table 
is unaltered. 

Second A-Cycle 

The second A-cycle of the operation again reads out 
the character being translated and replaces it in core 
storage with the contents of the A-register, which con- 
tains the character read out of the translate table on 
the B-cycle. The original A-field character is de- 
stroyed. 

A translate-with word-marks instruction destroys 
original A-field word marks but moves word marks 
from the translate table to the A-field. A translate- 
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without-word-marks instruction regenerates original 
A-field word marks into the A-field and moves trans- 
late-table word marks to the A-field. 

Figures 1-93 and 1-94 show how the translate instruc- 
tion affects processor-storage areas. No particular 
codes are specified. 

Timing. The formula for the translate-operation exe- 
cution time (T) for the 1460 is: 

T=.006(Li + 2 + 3N)ms. 

N = The number of characters in A-field to be translated. 

Li = 7 for TRANSLATE-WITHOUT- WORD-MARKS 
8 for TRANSLATE -WITH-WORD-MARKS 

Example: N = 100-character record 
T = 1.8 ms 



Load Record 

The translate feature includes a special move instruc- 
tion that moves characters and associated word marks 
in a record from one storage area to another. 



Op Code 
P 



A-address 

XXX 



B-address 

XXX 



d-character 
> 



The load record instruction consists of P (B-4-2-1- 
WM ) for the operation code, a 3-character A-address 
representing the address of the record to be moved, a 
3-character B-address representing the address of the 
field to which the record is moved, and a d-character 
with a bit configuration of 8-4-2. 

The operation moves characters and word marks in 
the A-field to the B-field, moving from low-numbered 
to high-numbered storage position up to and including 
an A-field group-mark with a word-mark, which stops 
the operation. Original B-field word marks are cleared. 
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Original A-field (record to be translated) 
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Original A-field (record to be translated) (Note: Same bit 
configurations as example translate-with-word-marks.) 



600 


601 


602 603 604 605 606 607 608 6 


74 675 


676 677 


1 1 1 1 1 1 1 1 IXH 1 1 1 1 


700 


701 


702 


703 


704 705 771 


772 773 774 775 


776 777 


1 1 1 1 1 1 « 1 1 1 1 1 1 1 



Translate 
Tables 
^600-677 600 601 602 60 3 604 605 606 607 608 672 673 674 675 676 677 
700-777 I I I I I I I" 



(Coded characters are assigned by the program) 

[X] Represents an unused table address (X08, X09, X18, X19, etc.) 



I I I I 1 I I I l^K I I I 1 I I 

Translate table 600-677 (coded characters are assigned by the program) 

K-71 Represents an unused table address (X08, X09, XI 8, X19, X28, 
^J X29, etc.) 
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Resultant A-field. © 604 means the contents of 604 (character and 
word mark) . 

T 900 600 > 
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Resultant A-field. (C) 604 means the contents of 604 (character and 
word mark) . 

T 900 600 



Figure 1-93. Translate-with-Word-Marks 



Figure 1-94. Translate Without Word-Marks 
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Transmission Control-Unit 
Attachment (1460) 

This feature is required when the ibm 1448 Transmis- 
sion Control Unit is attached to an ibm 1460 Data 
Processing System. For detailed information on the 
1448, refer to the ibm 1448 Transmission Control Unit, 
Form A24-3010, and ibm 1448 Transmission Control 
Unit with ibm 1460 Data Processing System, Form 
A24-3050. 



800 CPI Feature (1401) 

This feature provides the facility to operate 729 v mag- 
netic-tape unit at 800 cpi density with the 1401. The 
feature includes a tape-densities-option switch on 
the 1401 console, which is used to select one of the 
following pairs of densities: 200/556, 200/800, or 
556/800. The high or low density selected by the 
change-density switch on each tape unit operates in 
conjunction with the pair of densities selected by the 
tape-densities-option switch. 

This feature is standard on an ibm 1460 Data Proc- 
essing System with an ibm 1461 Input/Output Control, 
Model 2, and is effective for both the 729 v and 729 vi 
magnetic-tape units. 



IBM 1402 Special Feature 
Instructions and Timing 

Early Card Read (Model 1 Only; 
Standard on Model 3) 

The early-card-read feature for the ibm 1402 Card 
Read-Punch minimizes the decrease in card-reading 
speed caused by lengthy processing routines. In such 



routines, the card-reading mechanism can engage 
sooner, thus reducing the time between the reading of 
cards. 

The card reader operates at a rated speed of 800 
cycles per minute (one cycle every 75 milliseconds). 
The card reading speed depends on the timing of the 
read card instructions in the program. To effect con- 
tinuous card-reading at the rate of 800 cards per 
minute, a read card instruction must be given within 
10 milliseconds after the preceding card has been 
actually read into core storage (labeled Processing 
Time in Figure 1-95 ) . 

Normally, if processing time exceeds 10 ms in a 
basic card-read cycle, the rated card-reading speed 
decreases. This occurs because of the mechanical struc- 
ture of the card-read feed. There is only one time dur- 
ing the read cycle when the feeding mechanism can 
be engaged. If a read card instruction is given too late 
(processing time exceeds 10 ms), a card-read cycle is 
skipped, thus reducing the input speed from 800 to 400 
cards per minute ( Figure 1-96 ) . Similarly, if the time 
required for processing exceeds 85 ms, two read cycles 
are skipped, and the input speed is reduced to 266 
cards per minute, 

The early-card-read feature provides two additional 
points (clutch points) where the feeding mechanism 
can engage. When processing time between cards ex- 
ceeds 10 ms, the feed mechanism can engage 50 ms 
sooner than before. The time between card feeding is 
reduced to 100 ms rather than 150 ms. Instead of a 50 
percent reduction in the rated speed (to 400 cpm), 
there is only a reduction of 25 percent ( to 600 cpm ) as 
shown in Figure 1-97. 

Similarly, when processing time between cards ex- 
ceeds 35 ms, the feed mechanism can engage 25 ms 
sooner than before. The time between card feeding is 
reduced to 125 ms rather than 150 ms. Instead of a 50 
percent reduction in the rated speed (to 400 cpm), 
there is only a reduction of 40 percent ( to 480 cpm ) as 
shown in Figure 1-98. 

Figure 1-99 is a chart showing the card feed cycle 
times and the resultant cards per minute output. 



CARD READING 

800 CARDS PER MINUTE (Assume that operation code "\" was given during previous cycle) 



75 ms 



21 ms 
Read Start Time 



IH « « 



44 ms 
Card Reading 



The Read Start Time not available as Process Time 
unless the "Read Release" special feature is installed. 



Figure 1-95. Card Read Cycle 
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Figure 1-96. 400 CPM Operation 
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Figure 1-97. 600 CPM with Early Card Read 
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Figure 1-98. 480 CPM with Early Card Read 
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Card Feed 
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Figure 1-99. Card Feed Timings 



The hole-count check of prepunched data is begun at 
the punch-read station and is completed at the punch- 
check station after punching has occurred. 

Note: Punching in prepunched columns is acceptable, pro- 
vided that the resultant character is valid and that the punches 
read at the punch-feed-read station are not repeated. For ex- 
ample, an X can be punched in a card column that already 
contains a 2, but punching a K (X and 2 punches) at the 
punch station if either an X or a 2 was already in the card, 
results in a hole-count check. 

The d-character R activates the punch-feed-read 
brushes. It can be used with the operation codes punch 

CARD (4), WRITE AND PUNCH (6), and START PUNCH 

feed (9). If the combination instruction read and 
punch (5), or write read and punch (7) is given, 
read and punch errors occur. 



Punch Feed Read (Models I and 3 Only) 

In some applications it is desirable to read information 
into the system, calculate, and punch the results in the 
same card from which the input data was read. By 
using the punch feed read feature, the card at the 
punch-feed-read station can be read while the card 
ahead of it is being punched. To permit this type of 
operation, a special set of 80 reading brushes, called 
punch feed read, is added to the ibm 1402 Card Read- 
Punch feed, one station ahead of the punch station 
( Figure 1-100 ) . The R d-character specifies that the 
card is to be read from the punch side of the 1402. The 
normal read area ( storage locations 001-080 ) receives 
the information from the punch feed read in the same 
manner as information is read from the read feed. A 
validity and a columnar hole-count check is made on 
each card column read from the punch-feed-read 
brushes. MLP card codes cannot be read by the punch- 
feed-read brushes. 

The punching operation for machines equipped with 
punch feed read is the same as in the: basic 1401. Stor- 
age positions 101-180 are specified as the punch area, 
and a hole-count check is made the punch brushes. 



Read-Punch Feed 

Instruction Format. 

Mnemonic 
SPS P 
A RF 



Op Code 
4 



d-character 
R 



Function. When this instruction is used, the punch 
feed operates and reads the card entering the read 
station on the punch side. It also causes the card 
at the punch station to be punched. The R character 
modifier makes this instruction effective. 

Word Marks. Word marks are not affected. 

Timing. T = N ( L^ + 1 ) ms 4- punch start time 
(37 ms) and punching time of 184 ms (Figure 
1-101 ) . ( Punch start time can be used for processing 
if the punch release special feature is installed.) 

Note. An additional 3 ms is required in excess of the normal 
punch time of 181 ms when the punch feed-read-feature is 
used. Processing time available is 19 ms. 
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Figure 1-100. Punch Feed Read Schematic 
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240 ms 
Punch Card Operation ■ 
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Figure 1-101. Punch Timing (Read Punch Feed) 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
Abb 



B-Add. Reg. 
181 



Example. Read the card at the punch feed read sta- 
tion and punch a card (Figure 1-102). 
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Assembled Instruction: 4 R 



Figure 1-102. Read Punch Feed 



Processing 
Time 



Example. Read the card at the punch-feed-read sta- 
tion, punch a card, and branch to START6 (0598) 
for the next instruction ( Figure 1-103 ) . 
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Assembled Instruction: 4 598 R 
Figure 1-103. Read-Punch Feed and Branch 



Read-Punch Feed and Write 



Read-Punch Feed and Branch 



Instruction Format. 



Mnemonic 


Op Code 


1-address 


d-character 


SPS P 
A RF 


4 


XXX 


R 



Function. This instruction causes the same function 
as read-punch feed, except that an automatic branch 
to the I-address is effected. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms + punch start time 
( 37 ms ) and punching time of 184 ms. ( Punch start 
time can be used for processing if the punch-release 
special feature is installed.) 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
BI 



B-Add. Reg. 
081 



Instruction Format. 

Mnemonic 
SPS WP 
A WRF 



Op Code 
6 



d-character 
R 



Function. This instruction causes the printer to oper- 
ate and print a line, and the punch unit to read a 
card, and also causes the card at the punch station 
to be punched. The d-character R specifies that the 
card at the punch feed station is to be read. The 
printer takes priority and operates first, but the 
signal to start the punch feed read is automatically 
given before the end of the print operation, so that 
actual card reading starts soon after the print cycle 
is complete. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms + the timing conditions 
for print and punch overlap (see Write and Punch 
Operation Timing Chart — Figure E-44). The print 
operation normally takes 84 ms. Punch start time is 
37 ms and the punch reading time is 184 ms. An 



7-60 



additional 3 ms are added to the normal punching 
time of 181 ms. Normal processing time available 
is 19 ms. 

Note. If the print-storage special feature is installed in the sys- 
tem, the automatic signal to start the punch-feed-read opera- 
tion is given shortly after the transfer of data to the print 
storage area. Thus, additional processing time can be gained 
by using print storage. 



Address Registers After Operation. 



I- Add. Reg. 

NSI 



A-Add. Reg. 
Abb 



B-Add. Reg. 
081 



Example. Write a line, read a card at the punch-feed- 
read station, and punch a card (Figure 1-104). 
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Assembled Instruction: 6 R 
Figure 1-104. Read-Punch Feed and Write 



Read-Punch Feed, Write and Branch 



Instruction Format. 



Mnemonic 


Op Code 


I-address 


d-character 


SPS WP 


6 


XXX 


R 


A WRF 









Function. Same as the read-punch feed and write 
except that the program branches to the I-address 
for the next instruction. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms + the timing conditions for 
print and punch overlap (see Write and Punch Oper- 
ation Timing Chart — Figure E-44). The print opera- 
tion normally takes 84 ms. Punch start time is 37 
ms and the punch reading time is 184 ms. An addi- 
tional 3 ms are added to the normal punching time 
of 181 ms. Normal processing time available is 19 ms. 

Note. If the print-storage special feature is installed in the sys- 
tem, the automatic signal to start the punch-feed-read opera- 
tion is given shortly after the transfer of data to the print- 
storage area. Thus, additional processing time can be gained 
by using print storage. 



Address Registers After Operation. 



I-Add. Reg. 

NSI 



A-Add. Reg. 
BI 



B-Add. Reg. 
081 



Example. Print a line, read and punch a card from the 
punch side of the ibm 1402, and branch to START6 
( 0895 ) for the next instruction ( Figure 1-105 ) . 
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Assembled Instruction: 6 895 R 
Figure 1-105. Read-Punch Feed Write and Branch 
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IBM 1403 Special Feature 



Selective-Tape-Listing Feature 

The selective-tape-listing feature can be attached to 
any model of the ibm 1403 Printer so that output re- 
sults of data processed on a system can be printed on 
adding-machine style paper tapes. 



Operation 

An ibm 1403 Printer with the selective-tape-listing 
feature installed continues to operate at regular 1403 
speeds. Each tape is individually linespaced, one line 
at a time (no skipping or ejecting is possible). Tape is 
spaced by using modified 1403 control carriage Op 
code ( F ) , when used with a d-character of A through 
H, which signals a single linespace for the correspond- 
ing tape. (The space operation takes place after the 
next print operation. ) The modifier characters and the 
tapes they control are: 

A - Tape 1 
B - Tape 2 
C - Tape 3 
D - Tape 4 
E - Tape 5 
F - Tape 6 
G - Tape 7 
H - Tape 8 



When a double-width tape is used, two tape line- 
space instructions are given, using the d-characters 
corresponding to the positions occupied by the double- 
width tape. If additional linespacing is wanted, a tape 
linespace instruction (control carriage) Op code and 
the specific d-character and a print instruction ( 2 ) are 
given. The print operation is a dummy print operation, 
and the print area in core storage should be clear so 
that nothing is printed. The linespace operation occurs 
after the print operation. 

To equalize the ribbon wear, the customer can vary 
the location of the master tape. This can be done by 
using the same width tape in another location and 
altering the program ( changing the d-character to the 
character that corresponds to the new location). Tapes 
can be pulled up manually before tearing them against 
the tear-bar portion of the tape-advancing mechanism 
(Figure 1-106). 

An end-of-tape condition, sensed at the tape-spool 
tray, stops the printing operation and turns on the 
1403 end-of-forms light. 

When programming selective-tape-listing, the pro- 
gram should not select more than four tape-feeding 
solenoids simultaneously. 



Control (Feature Mode Switch) 

A feature-mode switch is provided on the 1403. This 
switch temporarily disconnects the standard carriage- 
control circuits and activates the tape-feeding circuits 
when the tape-spool assembly tray is latched in the 
operating position. 
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Buffer Feature for the IBM 1009 
Data Transmission Unit 



The ibm 1009 Data Transmission Unit, with the buffer 
feature installed, can be attached to an ibm 1401 or 
1460 Data Processing System. With this feature in- 
stalled on the ibm 1009, data can be loaded and un- 
loaded to and from the transmission line while the 
processor is free to perform any other function. 

The buffer feature provides a 400-character core- 
storage buffer that is divided into four 100-character 
blocks. Blocks of 100 characters are loaded into buffer 
storage from the processor or unloaded from buffer 
storage into the processor by a single move or load 
instruction. After a block of 100 characters has been 
moved into the core-storage area of the processor 
(receive mode), testable latches can be interrogated 
by the program to determine whether more data is 
stored and available for transfer to the processor. After 
a block of 100 characters has been moved into the 1009 
buffer from the processor core storage (transmit mode), 
the program routine can interrogate the buffer to de- 
termine whether it can accommodate another block of 
100 characters. 

If additional data is available in the 1009 buffer 
( receive mode ) , or additional space is available in the 
1009 buffer ( transmit mode ) , the program can initiate 
another move or load instruction. The B-address of 
the move or load instruction should be increased by 
100 before the instruction is executed. This procedure 
is followed until a group-mark with a word-mark ( end- 
of -message) is detected in the processor core storage 
(transmit mode) or an end-of -message is detected in 
the 1009 buffer storage ( receive mode ) . The processor 
program must determine the validity of the data re- 
ceived by testing the appropriate latch. The data is 
processed if it is valid. If the data is invalid, it is auto- 
matically retransmitted a maximum of two more times. 
A counter in the 1009 buffer keeps track of the number 
of transmissions made during an error routine; how- 
ever, the retransmission of data is under the control of 
the program. If the data is still invalid after three 
transmissions the transmission of data ceases, and an 
alarm sounds, indicating operator intervention is re- 
quired. 

The buffer feature also provides the 1009 with the 
ability to answer automatically and establish a tele- 
phone connection for transmission of data and to dis- 
connect at the end of transmission without operator 
intervention. The direction of the transmission can be 
automatically controlled through appropriate program- 
ming. 



Maximum Processor Time Required for 
Movement of Dafa 

Blocks of 100 characters, with or without word marks, 
are transferred by each move or load instruction. The 
following formula can be used to calculate the time 
involved in moving a 100-character block of data to or 
from the buffer. 

Timing. T = 9N + IN + 1L + 99N or 109N + 1L 

(without indexing) ms. 
T = 9N + IN + 3N + 1L + 99N or 112N + 1L 

(with indexing) ms. 
L = Line speed in ms. 
N = .0115 (1401); .006 (1460) ms. 



IBM 1009 with Buffer (Instructions) 

Several processor instructions are expanded to provide 
program control for operations that involve the ibm 
1009 Data Transmission Unit with buffer feature 
installed. 



Initialize a Message Transmission (XMIT) 



Instruction Format. 



Mnemonic 
CU 



Op Code 

U 



A-address 
%D1 



d-character 
E 



Function. This instruction initiates a start-of-message 
signal if the 1009 is in a send-run condition (trans- 
mit-receive switch is set to transmit). If the 1009 
is in a receive-run condition (transmit-receive switch 
set to receive) the instruction causes the processor 
to interlock and an alarm to sound, signaling that 
operator intervention is necessary. This instruction is 
also used when the transmit, receive, and automatic 
switch is set to the automatic position ( buffer fea- 
ture installed ) and a K E ( set direction to trans- 
mit) instruction has been issued. 

The A-address specifies the 1009, and the d-char- 
acter specifies the start transmission operation. 

Word Marks. Word marks are not affected. 
Timing. T = N (Li + 1) ms. 
Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 

%41 



B-Add. Reg. 
d41 
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Initialize a Reply from Receiver (RCV) 



Move Character from the Receiving 1009 



Instruction Format. 



Instruction Format. 



Mnemonic 


Op Code 


A-address 


d-character 


CU 


U 


%D1 


D 



Function. The receiving 1009 signals the transmitting 
station that it is ready to receive and indicates the 
status of the previous message ( see branch if indi- 
cator on instruction). 

Word Marks. Word marks are not affected. 



Timing. T = N ( L r + 1 ) ms. 

Note. The transmit-receive switch on the receiving 1009 should 
be set to receive. If it is set to transmit, the processor is 
interlocked and an alarm is sounded to signal the operator. 
This instruction is also used when the transmit, receive, and 
automatic switch is set to the automatic position (buffer 
feature installed ) and a K D instruction has been issued. 



Address Registers After Operation. 



1-Add. Reg. 

NSI 



A-Add. Reg. 



B-Add. Reg. 
d41 



Mnemonic 
MCW 



Op Code 

M 



A-address 
%D1 



B-address 



d-character 
R 



Function. This instruction transfers 100 characters in 
the receiving 1009 buffer to the receiving processor 
core-storage location starting with the position 
specified by the B-address. The d-character specifies 
a receive operation. 

Word Marks. Word marks are not affected. 



Timing. T 



109N + 1L (see Maximum Processor Time 
Required for Movement of 
Data) 
Timing. T = 112N + 1L (with indexing) 

Note. When the 1009 recognizes the end-of-message condition, 
the receiving processor gets an end-of -message-receive signal 
and inserts a group mark in the core-storage location im- 
mediately beyond the location containing the last character of 
the message. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 



B-Add. Reg. 
B + 100 or GM + 1 



Move Character to the Transmitting 1009 



Instruction Format. 

Mnemonic Op Code A-address B-address d-character 
MCW M %D1 xxx W 



Function. The transmitting processor sends 100 charac- 
ters to the 1009 buffer, starting with the position in 
core storage specified by the B-address. The d-char- 
acter, W, specifies a transmit operation. 

Word Marks. Word marks are not affected. 

Timing. T = 109N + 1L (see Maximum Processor Time 

Required for Movement of 
Data) 

Timing. T = 112N + 1L (with indexing) 

Note. If a group-mark with a word-mark is sensed in processor 
core storage, an end-of-message transmit condition is recog- 
nized. 

Address Registers After Operation. 

I-Add. Reg. A-Add. Reg. B-Add. Reg. 

NSI %41 B + 100 or GM + 1 



Load Character to the Transmitting 1009 



Instruction Format. 



Mnemonic 


Op Code 


A-address 


B-address 


d-character 


LCA 


L 


%D1 


xxx 


W 



Function. The transmitting processor sends 100 charac- 
ters, starting with the location specified by the B- 
address, to the transmitting 1009 buffer. The d-char- 
acter, W, specifies a transmit operation. 

Word Marks. If a word mark is associated with a char- 
acter, it is placed with the character in 1009 buffer 
storage during one transfer cycle. When the charac- 
ter is placed on the transmission line, the word mark 
is converted to a word separator. Placing the charac- 
ter and word separator on the transmission line takes 
two transmission cycles. 

Timing. T = 109N + 1L (see Maximum Processor Time 

Required for Movement of 
Data) 

Timing. T = 112N + 1L (with indexing) 
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Note. A group-mark with word-mark in processor core storage 
signals an end-of-message-transmit condition. 



Address Registers After Operation. 



I- Add. Reg. 
NSI 



A-Add. Reg. 

%41 



B-Add. Reg. 
B + 100 or GM + 1 



Load Character from the Receiving 1009 

Instruction Format. 



Mnemonic 


Op Code 


A-address 


B -address 


d-character 


LCA 


L 


%D1 


XXX 


R 



Function. This instruction transfers 100 characters in 
the receiving 1009 buffer to receiving processor core 
storage starting with the location specified by the 
B-address. The d-character, R, signals a receive op- 
eration. 

Word Marks. If a word mark is associated with a char- 
acter, it is received as a word separator followed by 
its associated data character, but converted to a 
word mark and placed with its associated character 
in the receiving 1009 buffer storage. This operation 
takes two transmission cycles. The character and as- 
sociated word mark are then transferred to processor 
core storage during one transfer cycle. 

Timing. T = 109N + 1L (see Maximum Processor Time 

Required for Movement of 
Data) 

Timing. T = 112N 4- 1L (with indexing) 

Note. When the 1009 recognizes an end-of-message condition, 
the receiving processor interprets an end-of-message-receive 
signal and inserts a group mark in the core-storage location 
immediately beyond the location containing the last character 
of the message. 



Address Registers After Operation. 



1-Add. Reg. 
NSI 



A-Add. Reg. 
841 



B-Add. Reg. 
h 100 or GM + 1 



d-character 


Indicator 


Station 


1 


1009 Ready 


RCV or XMIT 


2 


Buffer Service 


RCV or XMIT 


3 


Reply Good 


XMIT 


4 


Reply Bad 


XMIT 


5 


Receive Error 


RCV 


e 


Attention 1009 


RCV or XMIT 


7 


Receive EOM 


RCV 


8 


Receive EOF 


RCV or XMIT 


Indicators. 







B xxx 1 — This indicator turns on when the 1009 is in a run 
condition. If the 1009 is not in a run condition, the pro- 
gram should stop, or loop until the run condition is estab- 
lished. 

B xxx 2 — This indicator, when on, indicates to the processor 
that the 1009 is in a buffer-available condition when in 
either the transmit or receive mode. This indicator turns on 
the first time when 100 characters have been placed in the 
receive 1009 buffer or when a U%D1 E instruction has been 
issued when in a transmit mode. 

B xxx 3 — This indicator turns on if the signal sent to the 
transmitting station by the U8D1 D instruction specified 
that a good transmission occurred. The transmitting proc- 
essor should test this indicator and branch to the routine 
for the next message, if it is on. If the indicator is not on, 
the program should advance to test the transmission-error 
indicator. 

B xxx 4 — The reply-bad indicator turns on if the signal sent 
~ to the transmitting station by the U8DL D instruction 
specified that a transmission error occurred. The transmit- 
ting processor should test this indicator and branch to an 
error subroutine if an error occurred. 

B xxx 5 — This indicator, when on, indicates to the processor 

— that the condition for acknowledgment that has been set in 

the 1009 is error-reply. This indicator turns en when the 

first error character is detected in a message and remains 

on until the next U%D1 D instruction is issued. 

B xxx 6 — This indicator turns on when any one of the fol- 
lowing indicators turns on: branch-2, branch-3, branch-4, 
branch-7, and branch-8. When the branch-6 indicator is 
on, the 1009 requires program attention. 

B xxx 7 — This indicator, when on, indicates to the processor 
that the conditions for an acknowledgment have been set 
( reply-good or reply-bad ) in the 1009. This indicator turns 
on when the processor receives an end-of-message signal 
from the 1009 and remains on until the next U%D1 D in- 
struction is issued. 

B xxx 8 — This indicator, when on, indicates to the processor 
that the 1009 has received an EOF ( end-of-file ) signal 
from the remote terminal. 



Branch If Indicator On 



Instruction Format. 



Mnemonic 
B 



Op Code 
B 



1-address 



d-character 
X 



Function. This instruction tests the indicator specified 
by the d-character. If the indicator is on, the pro- 
gram branches to the I-address for the next instruc- 
tion. If it is off, the program continues with the next 
sequential instruction. 



Word Marks. Word marks are not affected. 



Timing. T = N (Li + 1) ms. 



Address Registers After Operation 
1-Add. Reg. 



Branch 
No Branch 

Branch 
No Branch 



BI 

NSI 

BI 

NSI 



A-Add. Reg. 

With Indexing 

BI 

BI 

Without Indexing 
BI 
BI 



B-Add. Reg. 

NSI 

dbb 

cleared to 

blanks 

dbb 
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Suppress 3-Second Alarm 

Instruction Format. 

Mnemonic Op Code 

SS K 



d-character 

A 



Function. This instruction prevents the 3-second alarm 
from sounding during a delay (such as tape rewind). 
Normal alarm functions will be restored when any 
subsequent instruction addresses the 1009. This in- 
struction can be given when a delay in processing 
can be foreseen. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms. 

Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
dbb 



B-Add. Reg. 
dbb 



Set Direction to Receive 

Instruction Format. 

Mnemonic Op Code 

SS K 



d-character 
D 



Function. This instruction is incorporated in the proc- 
essor receive program routine to set the line direc- 
tion to receive. This instruction is effective only if 
the transmit, receive, and automatic switch is set to 

AUTOMATIC. 

Word Marty. Word marks are not affected. 
Timing. T = N (Li + 1) ms. 



Address Registers After Operation. 



I-Add. Reg. 
NSI 



A-Add. Reg. 
dbb 



B-Add. Reg. 
dbb 



Set Direction to Transmit 

Instruction Format. 

Mnemonic Op Code 

SS K 



d-character 
E 



Function. This instruction is incorporated in the proc- 
essor transmit program routine to set the line direc- 
tion to transmit. This instruction is effective only if 
the transmit, receive, and automatic switch is set to 
automatic. 



Word Marks. Word marks are not affected. 
Timing. T = N (Li +1) ms. 



Address Registers After Operation. 



I-Add. Reg. 

NSI 



A-Add. Reg. 
dbb 



B-Add. Reg. 
dbb 



Send EOF (End-of-File) 

Instruction Format. 

Mnemonic 
SS 



Op Code 
K 



d-character 
F 



Function. This instruction is incorporated in the proc- 
essor transmit or receive program routine to initiate 
sending an EOF ( end-of-file ) code signal to the 
remote 1009. 

Word Marks. Word marks are not affected. 

Timing. T = N (Li + 1) ms. 
Address Registers After Operation. 



I-Add. Reg. 

NSI 



A-Add. Reg. 
dbb 



B-Add. Reg. 
dbb 



Operate in Load Mode 

Instruction Format. 

Mnemonic 
SS 



Op Code 
K 



d-character 
L 



Function. This instruction is .placed ahead of the 
U %D1 D instruction in the processor receive pro- 
gram routine if the receiving 1009 is operating in the 
load mode. This instruction causes all word separa- 
tors to be converted to word marks as they are re- 
ceived at the receiving 1009 and before they are 
placed in the receiving 1009 buffer. The receive sta- 
tion operates in a load mode until an end-of -message 
signal is received. 



Timing. T 



N (L T + 1) ms. 



Address Registers After Operation. 



I-Add. Reg. 

NSI 



A-Add. Reg. 
dbb 



B-Add. Reg. 
dbb 
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